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The DP8490 and DP5380 
Comparison Guide 


OVERVIEW 


National Semiconductor has released two products to sup- 
port the Small Computer System Interface (SCSI). These 
two products offer significant features over existing asyn- 
chronous SCSI devices such as: 


e Lower power 

e Lower cost 

e Higher speed 

¢ More functionality 
© Compatibility 


(25 mW vs 700 mW) 
(up to 4 Mbytes/sec) 


(with existing NCR5380) 
FEATURES OF NATIONAL’s DP8490 & DP5380 


Low Power 


The DP8490 Enhanced Asynchronous SCSI _ Interface 
(EASI) and the DP5380 Asynchronous SCSI Interface (ASI) 
are CMOS devices. The current drawn by the NCR5380 is 
140 mA while both the EASI and the ASI draw 4 mA max— 
and the EASI/ASI are specified with SCSI pins terminated 
with SCSI spec values! 


Low Cost 


National’s marketing strategy will ensure the EASI and ASI 
are the most competitively priced parts on the market. 


High Speed 

The high speed CMOS process used for the EASI and ASI 
means that DMA rates of up to 4 Mbytes per second are 
achievable. Currently there are no low cost high speed 8-bit 
DMA controllers that will provide the necessary speed. A 
common solution is to provide the simple DMA functionality 
as part of ASIC circuitry normally found in each application. 
National has published an application note on how to build a 
4 Mbytes/sec asynchronous SCSI interface using the EASI/ 
ASI devices to assist designers. 


The user should be aware that with this increase in speed 
comes the need and care on the user’s part in board design 
and layout. The EASI and ASI have reduced: read access 
times from 140 ns to 50 ns, write data hold times from 30 ns 
to 10 ns, and all other parameters correspondingly. This 
means the designer should ensure he has correctly generat- 
ed chip strobes. In particular pay attention to the generation 
of DACK, and the period of hand-over of the bus between 
the DMA and CPU. : 


improved Functionality 


The EASI provides new and enhanced functions to ease the 
firmware overhead. The major features are: 


new interrupts 

new interrupt status and mask structure 
extended arbitration 

loopback and other testing facilities 
microprocessor data bus parity 
improved SCSI and DMA timing 


New Interrupts 


The EASI adds interrupts for: arbitration complete, any 
phase mismatch, true end of DMA and microprocessor pari- 
ty error. The arbitration complete interrupt allows the firm- 
ware to program the EASI to arbitrate for the bus and inter- 
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rupt when done. True End of DMA interrupt overcomes the 
fault in the DP5380 when using it to send data on SCSI. 


New Interrupt Structure 


The DP5380 cannot be fully interrupt driven (e.g., No arbitra- 
tion complete interrupt)—the DP8490 can be! In the 
DP5380 the firmware must read 2 registers and then pro- 
cess the results to determine the cause of an interrupt. Not 
all interrupt conditions have a status bit in the DP5380. The 
DP8490 provides an interrupt status register which gathers 
all status into one register, with a dedicated status bit for 
each interrupt. An interrupt mask régister provides individual 
masking control of each interrupt. Finally, the design of the 
interrupt logic ensures interrupts will not be lost (they can be 
on the DP5380). 


Extended Arbitration 


The DP5380 device must be polled by the uP during arbitra- 
tion. Since this process does not start until the bus is free, 
the 4P may be polling for many milliseconds. The DP8490 
provides an interrupt on arbitration complete to allow the uP 
to handle other tasks such as cacheing data, overlapped 
seeks etc. The DP8490 also implements the 2.2 ys SCSI 
arbitration delay before interrupting the pP. 


Loopback Testing 


The DP8490 provides a loopback test mode. Each SCSI pin 
driver is disabled and looped back internally. The firmware 
may exercise the EASI to verify correct part operation. SCSI 
signal driving and monitoring, interrupts and DMA can all be 
tested. The EASI also provides programmable parity polarity 
(EVEN/ODD) for both uP and SCSI buses. These bits may 
be used to verify parity circuitry on all boards in a SCSI 
system. 


Microprocessor Parity 

The PCC-packaged DP8490 provides an extra pin for pP 
data bus parity. This enables checked data to be maintained 
throughout a system—even including controller buffer mem- 
ory. 

Improved Timing 


The DP5380 has some timing anomalies just like the 
NCR5380 on the SCSI and pP interfaces. The DP8490 fixes 
these. 


COMPATIBILITY 


The DP5380 is completely compatible with existing 
NCR5380 type devices—but offers higher speed and lower 
power. 


The DP8490 is also completely compatible with existing 
NCR5380 type devices except for one register bit. An un- 
used “‘test-mode” bit in the NCR5380 is replaced by an 
“Enhanced Mode” bit in the DP8490. Until this bit is set the 
DP8490 functions as a DP5380. Once set the enhanced 
features of the DP8490 are accessible. Since the DP8490 
powers up in DP5380 mode a// DP5380 sockets should be 
able to use a DP8490! 


For more information see Section 8 of the DP8490 data- 
sheet. 
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DP8490 Enhanced Asynchronous SCSI Interface (EASI) 


General Description 


The DP8490 EASI is a CMOS device designed to provide a 
low cost, high performance Small Computer Systems Inter- 
face. It complies with the ANS X3.131-1986 SCSI standard 
as defined by the ANSI X3T9.2 committee. It can act as 
both INITIATOR and TARGET, making it suitable for any 
application. The EAS! supports selection, reselection, arbi- 
tration and all other bus phases. High-current open-drain 
drivers on chip reduce application chip count by interfacing 
direct to the SCSI bus. An on-chip oscillator provides all 
timing delays. 

The DP8490 is pin and program compatible with the NMOS 
NCR5380 and CMOS DP5380 devices. NCR5380, DP5380 
or AM5380 applications should be able to use it with no 
changes to hardware or software. The DP8490 includes 
new features which make this part more attractive for new 
designs and performance upgrades. These new features in- 
clude P data bus parity, programmable parity for both SCSI 
and uP busses, loopback test mode, improved arbitration 
support, faster timing and extended interrupt control logic. 
The DP8490 is available in a 40-pin DIP or a 44-pin PCC. 


The EASI is intended to be used in a microprocessor based 
application, and achieves maximum performance with a 
DMA controller. The device is controlled by reading and 
writing several internal registers. A standard non-multi- 
plexed address and data bus easily fits any .P environment. 
Data transfers can be performed by programmed-|/O, pseu- 
do-DMA or via a DMA controller. The EASI easily interfaces 
to a DMA controller using normal or Block Mode. The 
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Connection Diagram 
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EASI can be used in either a polled or interrupt-driven envi- 
ronment. The EASI includes enhanced features for interrupt 
control. 


Features 


SCSI Interface 
m Supports TARGET and INITIATOR roles 
m Parity generation with optional checking 
m Programmable parity polarity (ODD/EVEN) 
m Arbitration support—can interrupt when done 
m Direct control/monitoring of all SCSI signals 
m@ High current outputs drive SCSI bus directly 
mw Faster and improved timing 
mw Very low SCSI bus loading 


uP Interface 
=m Memory or |/O-mapped control transfers 
m Programmed-I/O or DMA data transfers 
m Normal or Block-mode DMA 
mw Fast DMA handshake timing 
w Individually maskable interrupts 
m Active interrupts identified in one register 
@ Optional data bus parity generation/checking 
m Programmable parity polarity (ODD/EVEN) 
m Loopback test mode 


Table of Contents 
4.0 FUNCTIONAL DESCRIPTION 
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9.0 APPLICATION GUIDE 
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1.0 Functional Description 


1.1 OVERVIEW 


The EASI is designed to be used as a peripheral device in a 
pP-based application and appears as a number of read/ 
write registers. Write registers are programmed to select de- 
sired functions. Status registers provide indication of operat- 
ing conditions. In an application extensive use of interrupts 
is desirable. The EAS! incorporates an improved interrupt 
Structure which enables fully interrupt-driven operation. In 
the enhanced mode interrupts can be individually masked or 
enabled, and a status register identifies all active interrupt 
requests. ; 


For best performance a DMA controller can be easily inter- 
faced directly to the EASI. The EASI provides request/ac- 
knowledge and wait-state signals for the DMA interface. 


The SCSI bus is easily controlled via the EASI registers. Any 
bus signal may be asserted or deasserted via a bit in the 
appropriate register, and the state of every signal is avail- 
able by reading registers. This direct control over SCSI sig- 
nals allows the user to implement all or part of the protocol 
in firmware. The EASI provides hardware support for much 
of the protocol, and all speed-critical steps are handled by 
the EASI. | 


The EASI provides the following SCSI support: 

e Programmed-i/O transfers for all eight information trans- 
fer types, with or without parity. 

e Data transfers via DMA, in either block or non-block 
mode. The DMA interface supports most devices. 

¢ Individual setting/resetting and monitoring of every SCSI 
bus signal. 

e Automatic release of the bus for BSY loss from a TAR- 
GET, SCSI RST, and lost arbitration. 

e Automatic bus arbitration with an optional interrupt upon 
completion—the pP has only to check for highest priori- 
ty. The 2.2 ys arbitration delay can be optionally per- 
formed by the EASI. 
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© Selection or Reselection of any bus device. The EASI will 
respond to both Selection and Reselection. 


¢ Optional automatic monitoring of the BSY signal from a 
TARGET with an interrupt after releasing contro! of the 
bus. 


e Optional parity polarity selection. Default after reset is 
ODD, but EVEN generation and checking can be pro- 
grammed for diagnostic purposes and to determine 
whether a device supports parity when first making a 
connection. 


Figure 1 shows an EASI in a typical application, a low cost 
embedded SCSI disk controller. In this application the 8051 
single-chip wP acts as the controller and the dual DMA 
channels in the DP8475 allow one for the disk data and the 
other for SCSI data. The PAL provides chip selection as well 
as determining who has control of the bus. The advantage 
of using a uP with on-board ROM is that there is more free 
time on the external bus. 


1.2 wP INTERFACE 


Figure 2 shows a block diagram of the EASI. Key blocks 
within the EASI are Read/Write registers with associated 
decode and control logic, interrupt and DMA logic, SCSI bus 
arbitration logic, SCSI drivers/receivers with parity and the 
SCSI data input and output registers. The EASI has three 
interfaces, one to SCSI, one to a DMA controller and the 
third to a wP. The internal registers control all operation of 
the EASI. 


The pP interface consists of non-multiplexed address and 
data busses with associated control signals. The data bus 
can be programmed to use either ODD or EVEN parity. Ad- 
dress decode logic selects a register for reading or writing. 
The address lines AO-A2 select the register for P access- 
es while for DMA accesses the address lines are ignored. 
The decode logic also selects different registers or func- 
tions to be mapped into address 7, according to the pro- 
grammed mode (see Section 8). 
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FIGURE 1. EASI Application 


0678dG 


DP8490 


1.0 Functional Description (Continued) 
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FIGURE 2. EASI Block Diagram 


The register bank consists of twelve registers mapped into 
an address space of eight locations. Upon an external chip 
reset the registers are cleared (all zeroes)—the same as the 
NCR5380. Once the ENHANCED MODE bit in the. INITIA- 
TOR COMMAND REGISTER is set, three new registers can 
be accessed to utilize the extra features of the DP8490 
EASI. 


1.3 DMA INTERFACE 


The DMA logic interfaces to single-cycle, block mode, flow- 
through or fly-by controllers. Single byte transfers are ac- 
complished via the DRQ/DACK handshake signals. Block 
mode transfers use the READY output to control the speed 
(insert wait-states). An End Of Process (EOP) input from the 
DMA controller signals the EAS! to halt DMA transfers. An 
interrupt can be generated for DMA completion or an error 
(see Section 5). All DMA data passes through the SCSI data 
input and output registers, automatically selected during 
DMA cycles. . 


1.4 SCSI INTERFACE 


The EASI contains all logic required to interface directly to 
the SCSI bus. Direct control and monitoring of all SCSI sig- 
nals is provided. The state of each SCSI signal may be de- 
termined by reading a register which continuously reflects 
the state of the bus. Each signal may be asserted by writing 
a ONE to the appropriate bit. 


The EASI includes logic to automatically handle SCSI timing 
sequences too fast for wP control. In particular there is 
hardware support for DMA transfers, bus arbitration, selec- 
tion/reselection, bus phase monitoring, BSY monitoring for 
bus disconnection, bus reset and parity generation and 
checking. 


SCSI Interface 
Control Logic 


Data Input 
Register 


Data Output 
Register 


Control 
Registers 


Interrupt 
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READY 
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The EASI arbitration logic controls arbitration for use of the 
SCSI bus. The uP programs the SCSI device ID into the 
EASI, then sets the ARBITRATE bit. The EAS! will interrupt 
the .P when one of three events occurs: arbitration is lost; 
arbitration has completed and the ID priorities need to be 
checked; or arbitration is complete and the 2.2 ws SCSI 
Arbitration delay has expired. Arbitration can be invoked 
with the enhanced feature of an interrupt on completion or 
the expiration of the SCSI Arbitration delay. These extra 
steps are programmed via the EXTRA MODE REGISTER 
(EMR). The INITIATOR COMMAND REGISTER (ICR) is 
read to determine whether arbitration has been won or lost. 


The BSY signal is continuously monitored to detect bus dis- - 
connection and bus free phases. The EAS! incorporates an 
on-board oscillator to determine Bus Settle, Bus Free and 
Arbitration Delays. The oscillator tolerance guarantees all 
timing to be within the SCSI specification. 


The EASI incorporates high-current drivers and SCHMITT 
trigger receivers for interfacing directly to the SCSI bus. This 
feature reduces the chip count of any SCSI application. The 
driver/receivers also incorporate loopback logic which is 
enabled by an EMR bit. The Loopback mode enables test- 
ing of all EASI functions without interfering with the SCSI 
bus. 


1.5 PARITY 


The EASI provides for parity protection on both the wP and 
SCSI interfaces. Each data bus has eight data bits and one 
parity bit (only the PCC part provides P parity, both the DIP 
and PCC provide SCSI parity). In each case the parity may 
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1.0 Functional Description (Continued) 


be enabled via a register bit. A parity error can be pro- 
grammed to cause an interrupt. Additionally the parity may 
be programmed to be either ODD or EVEN. This has a par- 
ticular use on the SCSI interface where programming EVEN 
parity allows diagnostics, or determining whether a device 
supports parity. The inclusion of uP parity allows develop- 
ment of controllers that maintain data integrity right-from the 
media to the host system. 


1.6 INTERRUPTS 


The EASI is intended to be used in an interrupt-driven envi- 
ronment. Each function can be programmed to cause an 


2.0 Pin Descriptions 
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interrupt. In ENHANCED MODE two registers are used to 
control interrupts—the INT STATUS REGISTER (ISR) and 
the INT MASK REGISTER (IMR). Each interrupt can be 
masked from interrupting via the IMR. When an interrupt is 
recognized by the pP, reading the ISR will display all active 
interrupt sources. The ISR contents remain unchanged until 
an interrupt reset is programmed. A shadow register behind 
the ISR guarantees that interrupts occurring while others 
are serviced will not be lost. 


Function 


Chip Select: an active low enable for read or write operations, accessing 
the register selected by AO-A2. 


Address 0-2: these three signals are used with CS, RD, and WR to address 
a register for read or write. 


Read: an active low enable for reading an internal register selected by 
AO-A2 and enabled by CS. It also selects the Input Data Register when 
used with DACK. 


Write: an active low enable for writing an internal register selected by 
AO-A2 and enabled by CS. It also selects the Output Data Register when 


4-7 


used with DACK. 


Reset: an active low input with a Schmitt trigger. Clears all internal registers. 
(SCSI RST unaffected.) 


Data 0-7, P: bidirectional TRI-STATE® signals connecting the active high 
»-P data bus to the internal registers. The PCC part offers an optional parity 
on the »P data bus. If the parity option is not enabled the pin is TRI-STATE. 


Interrupt: an active high output to the uP when an error has occurred, an 
event requires service or has completed. 


DMA Request: an active high output asserted when the data register is 
ready to be read or written. DRQ occurs only if DMA mode is enabled. The 
signal is cleared by DACK. 


DMA Acknowledge: an active low input that resets DRQ and addresses the 
data registers for input or output transfers. DACK is used instead of CS by 
the DMA controller. 


Ready: an active high output used to control the speed of block mode DMA 
transfers. Ready goes active when the chip is ready to send/receive data 
and remains inactive after the transfer until the byte is sent or until the DMA 
mode bit is reset. 


End of Process: an active low signal that terminates a block of DMA 
transfers. It should be asserted during the transfer of the last byte. 


DBO-DB7, DBP: SCS! data bus with parity. DB7 is the MSB and is the 
highest priority during arbitration. Parity is default ODD but can be 
programmed EVEN. Parity is always generated and can be optionally 
checked. Parity is not valid during arbitration. 


Reset: SCSI reset, monitored and can be set by EASI. 


1/0 Busy: indicates the SCSI bus is being used. Can be driven by TARGET or 
INITIATOR. 
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2.0 Pin Descriptions (Continue) 


Function 


- Select: used by the INITIATOR to select a TARGET or by the TARGET to 
‘reselect an INITIATOR. 


Acknowledge: driven by the INITIATOR and received.by the TARGET as 
part of the REQ/ACK handshake. 


Attention: driven by the INITIATOR to indicate an attention condition to the 
TARGET. 


Request: driven by the TARGET and received Py the INITIATOR as part of 
the REQ/ACK handshake. 


Input/Output: driven by the TARGET to control the direction of transfers on 
the SCSI bus. This signal also aelngineniee between selection and 
reselection. 


Command/ Data: driven by the TARGET to indicate whether command or 
data bytes are being transferred. 


Message: driven by the TARGET during message phase to identify 
message bytes on the bus. 


Vec; GND: +5 Vpc is required. Because of very large switching currents, 
good decoupling and power distribution is mandatory. 
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3.0 Register Description 


3.1 GENERAL 

The DP8490 EASI is a register-based device with eight ad- 
dressable locations used to access twelve registers. Some 
addresses have dual functions depending upon whether 
they are being read from or written to. Two basic operating 
“modes” result in differences in the registers accessed 
through address 7. Device operation is described in Section 
4 but mode differences are highlighted in this section and 
Section 8. 

The EASI operates in one of two modes—NORMAL (MODE 
N) and ENHANCED (MODE E). Switching between the 
modes is performed by setting or resetting bit 6 in the Initia- 
tor Command Register. 

In MODE N, EAS! registers appear the same as the 
DP5380. In MODE E, address 7 accesses enhanced logic 
features. To help identify these differences .the register de- 
scription is split into two subsections. The first describes the 
registers in MODE N. The second describes the register 
differences when in MODE E. 

Figure 3.7 summarizes the register map in MODE N. Note 
that for registers reading or writing SCSI signals the SCSI 
name is used for each bit. Although the SCSI bus is active 
low, the registers invert the SCS! bus. This means an active 
SCSI signal is represented by a ONE in a register and an 
inactive signal by a ZERO. 


Output Data Register 
Current SCSI Data 
Initiator Command Register 
Mode Register 2 

Target Command Register 
Select Enable Register 
Current SCS! Bus Status 
Bus and Status 

Start DMA Send 

Start DMA Target Receive 
Input Data Register 

Start DMA Initiator Receive 
Reset Parity/Interrupts 


FIGURE 3.1. Normal Mode Registers 
3.2 NORMAL MODE REGISTERS 


OUTPUT DATA REGISTER (ODR) 

8 Bits HA 0 Write Only 

This is a transparent latch used to send data to the SCSI 
bus. The register can be written by uP cycles or via DMA. 
DMA writes automatically select the ODR at Hex Address 0 
(HA 0). This register is also written with the ID bits required 
during arbitration and selection/reselection phases. Data is 
latched at the end of the waite cycle. 


Bit 7 Bit 0 


| be7 | bee | bas | bea | bes | bee | bat | DBO 


Output Data Register 
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CURRENT SCSI DATA (CSD) 
8 Bits HA 0 Read Only 


This register enables reading of the current SCSI data bus. 
If SCSI parity checking is enabled it will be checked at the 
beginning of the read cycle. The register is also used for uP 
accesses of SCSI data during programmed-!/O or ID check- 
ing during arbitration. Parity is not valid during arbitration. 
DMA transfers select the IDR (HA 6) instead of the CSD 
register. 


Bit 7 Bit 0 


| be? | bee | bas | bed | Des | bee | DBT | DBO | 


Current SCSI Data 


INITIATOR COMMAND REGISTER (ICR) 
8 Bits HA 1 Read/Write 


This register is used to control the INITIATOR and some 
other SCSI signals, and to monitor the progress of bus arbi- 
tration. Most of the SCSI signals may also be asserted in 
TARGET mode. Bits 5 to 0 are reset when BSY is lost (see 
MR2 description). 


Bit 7 Bit 0 


my ae een een eee, ee 


Initiator Command Register 


DBUS: Assert Data Bus Bit 0 
0 Disable SCSI data bus driving. 


1 Enable contents of Output Data Register onto the 
SCSI data bus. SCSI parity is also generated and driv- 
en on DBP. 


This bit should be set when transferring data out of the EASI 
in either TARGET or INITIATOR mode, for both DMA or 
programmed-I/O. In INITIATOR mode the drivers are only 
enabled if: Mode Register 2 TARGET MODE bit is 0, and 
1/0 is false, and C/D, 1/0, MSG match the contents of the 
Target Command Register (phasematch is true). In TAR- 
GET mode only the MR2 bit needs to be set with this bit. 


Reading the ICR reflects the state of this bit. 
ATN: Assert Attention Bit 1 
0 Deassert ATN 


1 Assert SCSI ATN signal. The MR2 TARGET MODE bit 
must also be false to assert the signal. 


Reading the ICR reflects the state of this bit. 
SEL: Assert Select Bit 2 
0 Deassert SEL 


1. Assert SCSI SEL signal. Can be used in INITIATOR or 
TARGET mode. 


Reading the ICR reflects the state of this bit. 
BSY: Assert Busy _ Bit 3 
0 = Deassert BSY. 


1 Assert SCSI BSY signal. Can be used in INITIATOR or 
TARGET mode. 


Reading the ICR reflects the state of this bit. 


0678dd 


DP8490 


3.0 Register Description (Continued) 

ACK: Assert Acknowledge ___ Bit 4 

0  Deassert ACK. 

1 Assert SCSI ACK signal. The MR2 TARGET MODE bit 
must also be false to assert the signal. 

Reading the ICR reflects the state of this bit. 

DIFF: Differential Enable Bit5 Write 

0 __— This bit must be reset to 0. 

LA: Lost Arbitration Bit5 Read 

0 Normally reset to 0 to show arbitration not lost or not 
enabled. 

1 Will be set when the EASI loses arbitration, i.e. when 
SEL is true during arbitration AND the Assert SEL bit 
of this register is false. 

A 1 in this bit means the EASI has arbitrated for the bus, 

asserted BSY and its ID on the data bus and another device 

has asserted SEL. The ARBITRATE bit in MR2 or the EMR 
must be set to enable arbitration. 

MODE: Operating Mode Bit6 Write 

0 Normal Mode (MODE N) is selected. 

1 Enhanced Mode (MODE E) is selected. 

AIP: Arbitration In Progress Bit6 Read 

0 Normally 0 to show no arbitration in progress. 

1 Set when the EASI has detected BUS FREE phase 
and asserted BSY and the Output Data Register con- 
tents onto the SCSI data bus. This bit remains set until 
arbitration is disabled. 

RST: Assert RST _—i+Bit 7 

0  Deassert RST. 

1 Assert SCSI RST signal. RST is asserted as long as 
this bit is 1, or until a wP Reset (RESET). 

After this bit is set the INT pin goes active and internal regis- 

ters are reset (except for the interrupt latch, MR2 TARGET 


MODE bit, and this bit). Reading the ICR reflects the state of 
this bit. 


MODE REGISTER 2 (MR2) 

8 Bits HA 2 Read/Write 

This register is used to program basic operating conditions 
in the EASI. Operation as TARGET or INITIATOR, DMA 
mode and type as well as some interrupt controls are set via 
this register. This is a read/write register and when read the 
value reflects the state of each bit. 


Bit 7 Bit 0 


[BLK | TARG | PcHK | PINT | EOP | Bsy | DMA ARB | 


Mode Register 2 

ARB: Arbitrate Bit 0 

0 _— Disable arbitration 

1 Enable arbitration. The EASI will wait fora BUS FREE 
phase then arbitrate for the bus. Before setting this bit 
the Output Data Register should contain the SCSI de- 
vice ID—a single bit set only. The status of the arbitra- 
tion process is given in the AIP and LA bits (6,5) in the 
Initiator Command Register. 
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DMA: DMA Mode Bit 1 

0 Disable DMA mode 

1 Enable DMA operation. This bit should be set then one 
of address 5 to 7 written to start DMA. The TARGET 
MODE bit in the ICR and the phase lines in the TCR 
should have been set appropriately. The DBUS bit in 
the ICR must be set for DMA send operations. BSY 
must be active in order to set this bit. The phase lines 
must match the contents of the TCR during the actual 
transfers. In DMA mode EASI logic automatically con- 
trols the REQ/ACK handshakes. 

This bit should be reset by a P write to stop any DMA 
transfer. An EOP signal will not reset this bit. During 
DMA, CS and DACK should not be active simulta- 
neously. 

This bit will be reset if BSY is lost during DMA mode. 

BSY: Monitor Busy _ Bit 2 

0 Disable BSY monitor. 

1 Monitor SCSI BSY signal and interrupt when BSY goes 
inactive. When this bit goes active the lower 6 bits of 
the ICR are reset and all signals removed from the 
SCSI bus. This is used to check for valid TARGET 
connection. 

EOP: Enable EOP Interrupt 

0 No interrupt for EOP. 

1 Interrupt after valid EOP condition. 

PINT: Enable SCSI Parity Interrupt 

0 No Interrupt on SCSI parity error. 

1 When SCSI parity is enabled via the PCHK bit, setting 
this bit enables an interrupt upon a SCSI parity error. 

PCHK: Enable SCSI Parity Checking Bit 5 

0 No SCSI parity checking. 

1 Enable checking of SCSI parity during read operations. 
This applies to either programmed I/O or DMA mode. 


Bit 3 


Bit 4 


TARG: Target Mode Bit 6 

0 Initiator Mode 

1 Target Mode 

BLK: Block Mode DMA Bit 7 


0 Non-block DMA 

1 When set along with DMA bit (1), enables block mode 
DMA transfers. In block mode the READY line is used 
to handshake each byte with the DMA controller in- 
stead of the DRQ/DACK handshake used in non- 


block mode. 
TARGET COMMAND REGISTER (TCR) 
4 Bits HA 3 Read/Write 


This register is used to control TARGET SCSI signals and to 
program the desired phase during INITIATOR mode. During 
DMA transfers the SCSI phase lines (C/D, MSG, I/O) must 
match the contents of the TCR for transfers to occur. A 
phase mismatch halts DMA transfers and generates an in- 
terrupt. 


Bit 7 Bit 0 


[x [x] x] x [rea [se | 70 | 70 


Target Command Register 
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3.0 Register Description (Continued) 

This is a read/write register and the value read reflects the 

State of each bit, except bits 4-7 which always read 0. 

1/0: Assert 1/0 _—iBit 0 

O _Deassert 170. 

1 Assert SCSI 170 signal. The MR2 TARGET MODE bit 
must also be active. 

C/D: Assert C/D __iBit 1 

O Deassert C7D 

1. Assert SCSI C/D signal. The MR2 TARGET MODE bit 
must also be active. 

MSG: Assert MSG _—Bit 2 

O  Deassert MSG. 

1 Assert SCSI MSG signal. The MR2 TARGET MODE bit 
must also be active. 

REQ: Assert REQ _—s—BBit 3 

0  Deassert REQ. 

1 Assert SCSI REQ signal. The MR2 TARGET MODE bit 
must also be active. This bit is used to handshake 
SCSI data via programmed-I/O. 


SELECT ENABLE REGISTER (SER) 
8 Bits HA 4 Write Only 
This write-only register is used to program the SCSI device 
ID for the EASI to respond to during Selection or Reselec- 
tion phases. Only one bit in the register should be set. When 
SEL is true, BSY false and the SER ID bit active an interrupt 
will occur. 
This interrupt is reset or can be disabled by writing zero to 
this register. Parity will also be checked during Selection or 
Reselection if the PCHK bit in MR2 is set. 

Bit 7 


_ba7 | pas | bes | bea | Das | Dee | 
Select Enable Register 


CURRENT SCSI BUS STATUS (CSB) 
8 Bits HA 4 Read Only 


This read-only register is used to monitor SCSI control Sig- 
nals and the SCSI parity bit. The SCSI lines are monitored 
during programmed-!/O transfers and after an interrupt in 
order to determine the cause. A bit is 1 if the corresponding 
SCSI signal is active. 


Bit 0 


Bit 7 


Ast | esy | Rea | wsa | c75 | 70 | set | 
Current SCSI Bus Status 


BUS AND STATUS REGISTER (BSR) 
8 Bits HA 5 Read Only 


This read-only register is used to monitor SCSI signals not 
included in the CSB, and internal status bits. This register is 
read after an interrupt (in MODE N) to determine the cause 
of an interrupt. Bit 0 or 1 are set to 1 if the SCSI signal is 
active. 


Bit 0 


Bit 7 Bit 0 


[eoma | ora | sper | int] PHM | Bsy | ATN] ACK 


Bus and Status Register 


4-11 


ACK: Acknowledge Bit 0 

This bit reflects the state of the SCSI ACK Signal. 

ATN: Attention Bit 1 

This bit reflects the state of the SCS! ATN Signal. 

BSY: Busy Error Bit 2 

0 No error 

1 The SCSI BSY signal has become inactive while the 
MR2 BSY (Monitor BSY) bit is set. This will cause an 
interrupt, remove ail EASI signals from the SCSI bus 
and reset the DMA MODE bit in MR2. 

PHSM: Phase Match Bit 3 

0 Phase Match. The SCSI C/D, 170 and MSG phase 
lines are continuously compared with the correspond- 
ing bits in the TCR. The result of this comparison is 
reflected in this bit. This bit must be 1 (phase matches) 
for DMA transfers. A phase mismatch will stop DMA 
transfers and cause an interrupt. 

I’. f: Interrupt Request Bit 4 

0 No interrupt 

1 Interrupt request active. Set when an enabled interrupt 
condition occurs. This bit reflects the state of the INT 
pin. INT may be reset by performing a Reset Parity/In- 
terrupt (RPI) function. 

SPER: SCSI Parity Error 

0 No SCSI parity error 

1 SCSI parity error occurred. This bit remains set once 
an error occurs until the RPI function clears it. The 
PCHK bit in MR2 must be set for a parity error to be 
checked and registered. 

DRQ: DMA Request Bit 6 

0 No DMA request 

1 DMA request active. This bit reflects the state of the 
DRQ pin. DRQ is reset by asserting DACK during a 
DMA cycle or by resetting the DMA bit in MR2. A Busy 
error will reset the MR2 DMA bit and thus will also 
clear DRQ. A phase mismatch will not reset DRQ. 

EDMA: End of DMA Bit 7 

0 Not end of DMA 

1 Set when DACK, EOP and either RD or WR are active 
simultaneously. Normally occurs when the last byte is 
transferred by the DMA. During DMA send operations 
the last byte transferred by the DMA may not have 
been transferred on SCSI so REQ and ACK should be 
monitored to verify when the last SCSI transfer is com- 
plete. This bit is reset when the MR2 DMA bit is reset. 

Note: In MODE E the EASI presents a true EDMA bit in bit 7 of the TCR. 
This feature removes the need to poll the REQ and ACK signals. 

START DMA SEND (SDS) 

OBits HA5 Write Only 

This write-only register is used to start a DMA send opera- 

tion. A write of don’t care data should be the last thing done 

by the uP. The MR2 DMA, BLK and TARG bits must have 

been programmed previously. 


Bit 5 


Bit 7 Bit 0 


Start DMA Send 
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3.0 Register Description (Continued) 


START DMA TARGET RECEIVE 
O0Bits HA6 Write Only 


This write-only register is used to start a DMA Target Re- 
ceive operation. Same comments as SDS apply. 


INPUT DATA REGISTER (IDR) 
8 Bits HA 6 Read Only 


This read-only register contains the SCSI data last latched 
during a DMA receive. Each byte from SCSI is latched into 
this register automatically by the EASI DMA logic. A DMA 
read (DACK and RD) automatically selects this register. Pro- 
grammed I/O SCSI data reads should use the CSD (HA 8). 


START DMA INITIATOR RECEIVE (SDI) 
OBits HA7 Write Only 


This write-only register is used to start DMA INITIATOR Re- 
ceive Operation. Same comments as SDS apply. An alter- 
native method of performing the SDI function is available in 
the Enhanced Mode Register. 


RESET PARITY/INTERRUPT (RPI) 
0 Bits HA 7 Read Only 


This read-only register is used to reset the parity and inter- 
rupt latches. Reading this register resets the SCSI parity, P 
parity, Busy Loss and Interrupt Request latches. It also re- 
sets the interrupt latches presented in the Interrupt Status 
Register (available in MODE E). 


An alternative method of performing the Reset Parity Inter- 
rupt function is available in the Enhanced Mode Register. In 
MODE E writing a value of 01 to bits 2 and 1 of the EMR will 
reset the same bits as a read from HA 7 in MODE N. The 
EMR FPI will also reset enhanced logic that has bits set in 
the Interrupt Status Register. 


3.3 ENHANCED MODE REGISTERS 


Addresses 0 to 6 remain the same as MODE N except for 
bit 7 of TCR, as described below. Address 7 is the SDI and 
RPI functions in MODE N, but in MODE E it directly access- 
es the Enhanced Mode Register (EMR) and indirectly ac- 
cesses the Interrupt Mask Register (IMR) and the Interrupt 
Status Register (ISR). 


When bit 6 in the ICR (HA 1) is set, HA 7 accesses the 
read/write EMR. The SDI and RPI functions performed 
when writing/reading HA 7 in MODE N are disabled. To 
perform these functions the EMR is used instead. 

Note that EMR functions are intended to be used in an inter- 
rupt-driven environment. Reading this register reflects the 
state of each bit. 


TARGET COMMAND REGISTER (TCR) 
5 Bits HA3 Read/Write 


This is the same as MODE N except for bit 7 which is de- 
scribed below. Note bits 4-6 always read 0. 


Bit 7: 


Bit 0 


juss | 076 | 10 | 


Target Command Register 
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EDMA: True End of DMA | 

0 Not End of DMA | 

1 Set when the last byte of data has been transferred. 
This bit is not set until REQ and ACK both go inactive 
following the DMA cycle during which EOP was assert- 
ed. Note that unlike the BSR EDMA bit, this bit reflects 
the true completion of DMA transfers. 


ENHANCED MODE REGISTER (EMR) 
8 Bits HA 7 Read/Write 


This register is accessed at HA 7 when the ICR MODE bit 
(6) is set. The register controls operation of enhanced logic 
and timing. Normally the application will leave the EAS! per- 
manently in MODE N or MODE E. 


Bit 7 


Bit 7 Bit 0 


[apris[MPeN|MPot|sPo.|Loor]eFNt|EFNO| ARB | 


Enhanced Mode —— 


ARB: Extended Arbitration Bit 0 
0 Disable extended arbitration 


1 Enable extended arbitration. This is an alternative bit 
to the MR2 ARB function. The EASI waits for a BUS 
FREE phase then arbitrates for the bus, asserting the 
contents of the ODR onto the SCSI data bus and as- 
serting BSY. The EASI will then wait the 2.2 ws SCSI 
Arbitration Delay, and set the Arbitration Complete bit 
in the ISR and cause an interrupt. As for the MR2 ARB 
function, the ICR LA and AIP bit can be examined to 
determine arbitration status. 


EFN1,0: Enhanced Function Bits 2,1 
00 No operation—these bits ALWAYS read 00. 


01 When this pattern is written the Parity and Interrupt 
latches are reset. This pattern should be followed by 
any other pattern to remove the reset (usually 00). 
This function replaces the RPI function performed 
when reading HA 7 in MODE N. Only the latches with 
ISR bits set to 1 will be reset. 

10 Start DMA Initiator Receive. At the end of the write 
cycle the SDI function is performed. There is no need 
to follow with another pattern as required with the RPI 
value (01). This function replaces the SDI function per- 
formed when writing HA 7 in MODE N. 

11. Read/Write ISR/IMR. When this pattern is written the 
NEXT read of HA 7 will access the ISR, or the NEXT 
write to HA 7 will access the IMR. This state ONLY 
lasts for the ONE following read OR write cycle. Fur- 
ther cycles will then access the EMR. 

LOOP: Loopback Mode__ Bit 3 

0 Normal operation 

1 When set: SCSI drivers are disabled and the SCSI 
|/O’s looped back inside the EASI, and both the TAR- 
GET and INITIATOR signals may be driven simulta- 
neously. This enables the pP to check EASI operation 
without affecting the SCSI bus. 

SPOL: SCSI Parity Polarity Bit 4 

0 SCSI parity is ODD (as per SCSI specification). 


1 SCSI parity is EVEN. This allows seqeete to be per- 
formed. 


3.0 Register Description (continued 


MPOL: »P Parity Polarity Bit 5 
O uP parity is ODD. 

1 pP parity is EVEN. 

MPEN: yP Parity Enable Bit 6 


O —_—pP parity checking and generation disabled. 


1 Enable checking of .P data bus parity during pP and 
DMA writes. Generate parity during uP and DMA 
reads. Parity errors will cause an interrupt and set the 
ISR MPE bit if not masked. 


APHS: Any Phase Mismatch Bit 7 
0 Disable phase mismatch detection 


1 Detect SCSI requests with a phase mismatch present. 
Is set when REQ goes active AND the SCSI phase 
lines do not match the contents of the TCR. Can be 
used in INITIATOR mode to interrupt on TARGET 
phase changes. 


INTERRUPT STATUS REGISTER (ISR) 
8 Bits HA7(EFN = 11) Read Only 


This register is accessed during the first read cycle after the 
EFN bits in the EMR have both been set to 1. Once read, 
successive accesses of HA 7 go to the EMR. This register 
provides ail interrupt status within one register. This is in- 
tended to make determination of interrupt sources easier in 
MODE E. In MODE N two registers must be read—the BSR 
and CSB. In MODE E only the ISR needs to be read. Addi- 
tionally each interrupt (except SCSI RST) has a correspond- 
ing status bit in the ISR. 


When the ISR is read all unmasked, enabled, active inter- 
rupt sources set their corresponding ISR bits to a ONE. The 
interrupt status is sampled at the beginning of the ISR read 
cycle. When an RPI function is performed via the EMR, only 
each interrupt latch with an ISR bit set will be reset. This 
means interrupts occurring since the last ISR read will not 
be lost. 


ISR bits may be individually masked via their corresponding 
bits in the IMR. 


Bit 7 Bit 0 


[SPE | wpe |eowalorHs|aPHs] asy | sex | are 


Interrupt Status Register 


ARB: Arbitration Complete Bit 0 


This bit is set when arbitration enabled by EMR ARB bit (0) 
has completed. Completion occurs in two ways: when the 
EASI loses arbitration and has asserted the LA bit in the 
ICR; or when the EASI has asserted the ID contained in the 
ODR onto the data bus, asserted BSY, then waited for the 
2.2 4s SCSI Arbitration Delay. 

SEL: Selection/Reselection Bit 0 

This bit is set when BSY is false, SEL is active, and any SER 
bit set to 1 has an active corresponding SCSI data bus bits. 
This situation occurs during Selection or Reselection phas- 
es. 

BSY: Busy Loss Bit 2 

This bit is the same as BSR bit 2. Set when the SCSI BSY 
signal becomes inactive while the MR2 BSY (monitor BSY) 
bit is set. 


4-13 


APHS: Any Phase Mismatch Bit 3 


Set when a REQ occurs while the SCS! phase lines do not 
match. Bit is set to enable detection of the contents of the 
TCR. EMR APHS (bit 7) must be 1 to allow this bit to be set. 


DPHS: DMA Phase Mismatch Bit 4 


Set when a SCSI DMA mode operation occurs with a phase 
mismatch. Similar to the APHS condition but restricted to 
DMA mode only. In MODE N this condition is not as easily 
determined. 


EDMA: End of DMA ___ Bit 5 


Set when REQ and ACK are both false following the DMA 
cycle during which EOP was asserted. This represents the 
true end of DMA operation. 


MPE: .P Parity Error _Bit 6 


Set when pP parity error is detected at the end of a pP or 
DMA write cycle. The MPEN bit in the EMR must be set for 
pP parity to be checked. 


SPE: SCSI Parity Error Bit 7 


Set when a SCSI parity error is detected when reading the 
CSD, during selection/reselection, or when the IDR is load- 
ed during DMA operation. The MR2 PCHK bit must be set 
for SCSI parity to be checked, and the MR2 PINT bit must 
be set to enable the interrupt. 


INTERRUPT MASK REGISTER (IMR) 
8 Bits HA 7 (EFN ='11) =‘ Write Only 


This register is accessed during the first write cycle after the 
EFN bits in the EMR have been set to 11. Once written, 
successive reads or writes at HA 7 access the EMR. 


This register has the same bit definition as the ISR. If a bit in 
the IMR is set to 1 that interrupt will be masked. The inter- 
rupt will be captured internally (if enabled) but will not cause 
an active INT signal. A bit reset to 0 will enable that interrupt 
to occur (if enabled) and will enable the ISR bit to be set to 
1. 


Bit 7 Bit 0 


[SPE | wre |eomalopHs]aPus| asy | seu [ARS 


Interrupt Mask Register 


4.0 Device Operation 


4.1 GENERAL 


This section describes overall operation of the EASI. More 
detailed information of data transfers, interrupts and reset 
conditions are covered in later sections. The operation de- 
scription covers 4.P accesses, SCSI bus monitoring, arbitra- 
tion, selection, reselection, programmed-I/O, DMA inter- 
rupts. Programming and timing details are covered. 


For information regarding interfacing to uPs and DMA con- 
trollers refer to Section 9. ' 


In the descriptions following, program examples are given in 
pseudo-C. This processor-independent approach should be 
clearest. These are backed up by flow charts in Appendix 
Al. 


For each section where appropriate the description is split 
into two, MODE N and MODE E. 
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4.0 Device Operation (Continued) 


FIGURE 4.2. uP Cycles 


4.2 uP ACCESSES 


The »P accesses the EASI via the CS, RD, WR and address 
and data lines in order to read/write the registers. Figure 4. 7 
shows typical timing. Note the use of non-multiplexed ad- 
dress and data lines. 


4.3 SCSI BUS MONITORING/DRIVING 


The SCSI bus may be monitored or driven at any time. Each 
bus signal is buffered and inverted by the EASI and can be 
read via the CSB, BSR and CSD registers. An active SCS! 
signal reads a 1 in the status registers. 

Each SCSI signal may be asserted by setting a bit in the 
TCR or ICR. Setting the bit to 1 asserts the SCSI signal. 
The following code demonstrates a byte transferred via pro- 
grammed-I/O in INITIATOR mode. 


{  /* Transfer one byte as Initiator */ 
while (NOT (TCR: REQ)); 
/* wait till TARGET asserts REQ */ 
data = input (CSD) ; 
/* parity is checked if enabled */ 
output (ICR, Assert ACK) ; 
while (TCR:REQ) ; 
/* wait till TARGET deasserts REQ */ 
output (ICR, 0); 
/* deassert ACK, ready for next byte */ 
} 


4.4 ARBITRATION 


This sub-section describes the arbitration support provided 
by the EASI and how to program it. 


4.4.1 MODE N Arbitration | 


Since the SCSI arbitration process requires signal sequenc- 
ing too fast for »Ps, hardware support is provided by the 
EASI. The arbitration process is enabled by bit 0 MR2 
(ARB). Prior to setting this bit the ODR should be pro- 
grammed with the device’s SCSI ID—a single bit. 


The EASI will monitor the bus for a BUS FREE phase. The 
BSY signal is continuously monitored. If continuously inac- 
tive for at least a SCSI Bus Settle Delay (400 ns) and SEL is 
inactive, a valid Bus Free Phase exists. After a period of 
SCSI Bus Free Delay (800 ns) the EASI asserts BSY and 
the ODR onto the SCSI data bus. The P should poll the 
ICR to determine when arbitration has started. The AIP bit in 
the ICR is set when the Bus Free Phase is detected and the 
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EASI is beginning the Bus Free Delay. Following the Bus 
Free Delay a 2.2 ys SCSI Arbitration Delay is. required be- 
fore examining the data bus to resolve the priorities of the 
ID bits. This delay must be implemented in firmware. The 
ICR Lost Arbitration (LA) bit must be examined to determine 
whether arbitration is lost. The LA bit is set if another device 
asserts SEL during arbitration. If the LA bit is 0 the data bus 
is read via the CSD register. The data is examined to re- 
solve ID priorities. If this device is the highest ID, assert SEL 
by setting ICR bit 2 to a 1. After waiting Bus Clear + Bus 
Settle Delays (1200 ns), the Selection Phase begins. These 
2 delays must be implemented in firmware. 


4.4.2 MODE E Arbitration 


The extended arbitration in MODE E is enabled by bit 0 of 
the EMR (ARB). This alternative offers two significant ad- 
vantages over MODE N. First the 2.2 ws SCSI Arbitration 
Delay is implemented by the EASI. Second the arbitration 
process may be interrupt driven. . 


In MODE N the EASI must be polled to see when the ICR 
AIP bit is set. After the appropriate delays, the LA bit and 
data bus are examined. If arbitration is lost or this device is 
not the highest priority the MR2 ARB bit must be reset to 0, 
then set to 1 again and the whole process restarted. This 
means the EAS! MUST be polled until arbitration is won— 
potentially many SECONDS, NEeee ms. This ties up the 
host pP. — 


In MODE E when the EMR ARB bit is set the EASI will: wait 
for BUS FREE phase; delay SCSI Bus Free Delay; assert 
BSY and the ODR onto DBO-DB7; delay SCSI Arbitration 
Delay; interrupt the pP. 


The »P should read the ISR and if the ISR bit 0 (ARB com- 
plete) is set examine ICR bits 5 and 6 (LA and AIP) to deter- 
mine whether arbitration is lost. If not lost the data bus is 
examined to resolve ID priorities. As for MODE N if arbitra- 
tion has failed the EMR ARB bit should be reset and then 
set again after first resetting the ARB interrupt. Note that the 
EMR ARB bit allows the pP. to carry on with other tasks 
while the EASI arbitrates. This means there is NO NEED to 
poll the EASI. 


4.5 SELECTION/RESELECTION 


The EASI can be used to select or reselect a device. The 
EASI will also respond to selection or reselection. Selecting 
or reselecting a device is the same in MODE N or MODE E. 
Response to selection or reselection can differ between the 
bus modes. 


, 
Hy 


4.0 Device Operation (continue) 


4.5.1 Selecting/Reselecting 


Selection requires programming the ODR with the desired 
and own device IDs; the data bus via ICR DBUS (bit 0); 
asserting ATN if required via ICR bit 1: asserting SEL via 
ICR bit 2; then resetting the MR2/EMR ARB bit. 


The SER should have been cleared to zero before Selec- 
tion/Reselection to ensure the EAS! does not respond. If 
Reselection is desired the 1/O line should also be asserted 
before SEL via TCR bit 0. 

Resetting the ARB bit causes the EASI to remove BSY and 
the ODR from the data bus. Thus the ICR Assert data bus 
bit is required to assert the bits for desired and own device 
IDs. 


BSY is then monitored to determine when the device has 


responded to (re)selection. If the device fails to respond an 
error handler should sequence the EASI off the bus. If the 
device responds the ICR DBUS and SEL bits should be re- 
set to remove these signals. If this is a Reselection the ICR 
BSY bit (3) should be set before removing the other signals. 


The bus is now ready to handle Information Transfer Phas- 
es. 


4.5.2 MODE N (Re)Selection Response 


The EASI responds to Selection or Reselection when the 
SER is non-zero. A (re)selected interrupt is generated when 
BSY is false for at least a Bus Settle Delay (400 ns); and 
SEL is true AND any non-zero bit in the SER has its corre- 
sponding SCSI data bus bit active. A Selection is disabled 
by zeroing the SER. If parity is supported it should be valid 
during (re)selection so it must be checked via the SPE bit 
(5) in the BSR. SCSI specification states that (re)selection is 
not valid if more than 2 data bits are active. This condition is 
checked by reading the CSD. 


When the selection interrupt occurs it is determined by read- 
ing the BSR and CSB registers. There is no dedicated 
status bit for (re)selection in MODE N, it must be determined 
by the absence of other interrupts, and the active state of 
the SEL signal. Reselection occurs when I70O is also active. 
See Section 6. 


4.5.3 MODE E (Re)Selection Response 


The same conditions for valid (re)selection apply as for 
MODE N. A (re)selection interrupt is generated as per 
MODE N. The difference is that the interrupt sets the SEL 
bit (1) in the ISR. In MODE E, reading the ISR enables exact 
determination of interrupt sources. This interrupt can be 
masked via bit 1 of the IMR. The interrupt is reset by pro- 
gramming the RPI function to the EMR. See Section 6 for 
further details. 


4.6 MONITORING BSY 


While an INITIATOR is connected to a TARGET the TAR- 
GET must maintain an active BSY signal. During DMA oper- 
ations the BSY signal is monitored by the EASI and will halt 
operations if it goes inactive. To enable BSY to be moni- 
tored at other times the MR2 BSY bit (2) should be set. An 
interrupt will be generated if BSY goes inactive while MR2 
BSY is set. 


In MODE N this interrupt sets bit 2 in the BSR. In MODE E 
this interrupt sets bit 2 in the BSR and bit 2 in the ISR. The 
interrupt may be masked via bit 2 of the IMR. 


4.7 COMMAND/MESSAGE/STATUS TRANSFERS 


Command, message and status bytes are transferred using 
programmed-I/O. The SCS! REQ/ACK handshake is ac- 
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complished by monitoring and setting lines individually. Data 
is output via the ODR and read in via the CSD register. 
The following code shows INITIATOR and TARGET pro- 
gramming for two of these cases. See Appendix A1 for flow- 
charts. 


Initiator Command Send 


MR2 = monitor BSY 
TCR = Command Phase 
while 


/* O2h */ 

(bytes) to do) { 

while (REQ) inactive) 
idle; /* CSB bit 5 = 

if (BSR: phase_match==0) 
phase error; 

else { 

ODR = data byte; 

ICR = Assert_ACk; 

while (REQ active) 

idle; /* CSB bit 5==1 */ 

ICR = deassert_ACK 

/* byte transfer complete */ 

byte count - -; 


0 */ 


} 
goto data phase; 
} 


Target Message Receive 


{ 


/* assumed Assert_BSY already set in ICR */ 


MR2 = TARG MODE OR PARITY CHECK 
OR PARITY INTERRUPT; 
ICR = Message_Out phase; /* 06h */ 


delay (Bus Settle); 
TCR = Assert_REQ; 
while (ACK inactive) 
idle; /* BSR bit 0 */ 
data = CSD; /* parity is latched */ 
if (BSR: parity error) 
error routine; 
else { 
TCR = deassert_REQ; 
while (ACK active) 
idle; 


/* message done, can change to next 
phase*/ 
j 


4.8 NON-BLOCK DMA TRANSFERS 


Data transfers may be effected by DMA. This method 
should be used for optimum performance. Two methods of 
DMA are available—block and non-block mode. This sec- 
tion describes non-block mode transfers. MODE N opera- 
tion is covered first followed by MODE E. 

The interface to the DMA controller uses the DRO, DACK, 
EOP lines in non-block mode. Each byte is requested (DRQ) 
and ack’d (DACK). Representative timing for a DMA read is 
shown in Figure 4.8.17. 
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4.0 Device Operation (continued) 
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FIGURE 4.8.1. Non-Block DMA Timing 


4.8.1 MODE N Non-Block DMA 


DMA operation involves programming the EASI with the set- 
up parameters, initiating the DMA cycles and checking for 
correct operation when the completion interrupt is received. 
The DMA controller should be programmed with the data 
byte count and the memory start address. Methods of halt- 
ing a DMA operation are covered in Section 4.11. 


Setting up the EASI requires enabling or disabling the fol- 
lowing: Data bus driving, DMA mode enable, BSY monitor- 
ing, EOP interrupt, parity checking, parity interrupt, TARGET 
Mode, bus phase. 


Once set up, DMA should be initiated by writing to address 
5, 6 or 7 as appropriate. The DMA controller should assert 
EOP during the transfer of the last byte, although this may 
be done by the pP if the DMA transfers (n—1) bytes and the 
uP transfers the last byte. See the application guide for 
more details (Section 9). 

Upon completion the ~P should check the following as re- 
quired: End of DMA, Parity Error, Phase Match, Busy Error. 
In MODE N the end of DMA occurs as a response to EOP. 
SCSI transfers may still be underway so REQ and ACK must 
still be checked to establish when the final byte is finished. 
The code below shows programming of the EAS! in each of 
the four DMA cases. One of these cases is shown in a flow 
diagram in Appendix A. 

Initiator Send /* DATA OUT PHASE */ 


{ 
Program DMA Controller; 


TCR = OOh; /* phase */ 
ICR = Olh; /* Assert_DBUS */ 
MR2 = OEh; 
SDS = 00; /* Start DMA Send */ 
while (NOT interrupt) 
idle; 
while (CSD :REQ) 
idle; /* wait for last SCSI byte 


transfer so phase 
is checked */ 
if(BSR:Busy_error OR NOT(BSR:End_of_DMA) ) 


error routine; 

else { /* DMA END */ 
MR2 = 04h; /* reset DMA bit */ 
ICR = 0; 
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Initiator Receive 


{ 


Target Receive 


“MR2 = 


/* DATA IN PHASE */ 


Program DMA Controller; 


TCR = Olh; /* phase */ 
MR2 = 3SEh; 
SDI = 0; /* Start DMA Init Rx */ 
while (NOT interrupt) 
idle; 


/* no need to wait for last SCSI handshake 
done since DMA done implies it is 
checked */ 

if (BSRsparity_error OR BSR:busy error 

or NOT (BSR End of DMA)) 
do error routines; 
else { /* End of DMA */ 
while (CSD:REQ) 
idle; /* wait for REQ inactive 
to deassert ACK */ 
MR2 = 04h; 
} 


/* DATA OUT PHASE */ 


Program DMA controller ; 


TCR = 0; /*phase*/ 
ICR = O8h; 
MR2 = 7Ah; /*check parity*/ 
SDT = 0; /*Start DMA Targ Rx*/ 
while (not interrupt) 
idle; 


/*when End of DMA occurs the last byte 
has been read and checked*/ 
if(BSRsparity_error OR NOT(BSR:End_of_DMA) 
error routine; 


else { /* End of DMA */ 
while (BSR:ACK) 
idle; 


/*Not True End of DMA in MODE N, so wait 
until SCSI bus inactive before 
changing phase */ 

40h; 

change phase as required; 
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4.0 Device Operation (Continued) 


Target Send /* DATA IN PHASE */ 


{ 
Program DMA Controller; 


ICR = Olh; /* phase */ 
ICR = 09h; 
MR2 = 4Ah; 
SDS = 0; /* Start DMA Send */ 
while (NOT interrupt) 
idle; 
if (NOT(BSR:END_of_DMA) ) 
error; 
else { /* DMA end */ 


repeat { 
while (CSB:REQ OR BSR:ACK) 
loop count = 3; 
loop count - <3} 
/* decrement */ 
until (loop count == 0); 
MR2 = 40h; 
Change phase as required; 
j 
j 
Some explanation of the final part of Target Send is re- 
quired. In this type of DMA operation it is very difficult to 
exactly determine the True End of DMA in MODE N. Simply 


. detecting REQ and ACK simultaneously inactive is not 


enough. 


Reference to Figure 4.8.2 will help to understand the follow- 
ing text. 

As shown in Figure 4.8.2, ACK going active causes the DRQ 
for the next byte and also REQ to go inactive. ACK going 
inactive allows REQ to go active for the next byte. If the 
INITIATOR is slow removing ACK the uP may sample the 
SCSI bus after the EOP interrupt at point A. Here both REQ 


‘and ACK will be inactive, but there is one more byte to 


transfer on SCSI. Due to chip timing delays this condition 
will not last more than 200 ns. A safe way to determine the 
True End of DMA is to sample REQ and ACK and ONLY 
when both are inactive in three successive samples will the 
uP be at point B in the figure. 


In MODE E, True End of DMA is correctly decoded and the 
End of DMA interrupt occurs as a result of this True condi- 
tion, thus there is no need to sample REQ and ACK. For this 
and other reasons operation in MODE E is strongly recom- 
mended. 


4.8.2 MODE E Non-Block DMA 


Operation for the Non-Block DMA in MODE E is essentially 
the same as MODE N. A primary difference is that in MODE 
E True End of DMA is decoded internally and this causes an 
interrupt. This feature removes the need to check for DMA 
End before moving to the next phase. Additionally, the use 
of the ISR allows easier determination of the end condition. 
For more information on interrupts see Section 6. 


Examples of code are given below. 


Initiator Receive /* DATA IN PHASE */ 


{ 


Program DMA controller; 


TCR = Olh; /* phase */ 
ICR = 40h; /* MODE E */ 
MR2 = BEh; 
EMR = 04h; /7* Start DMA INIT Rx */ 
while (NOT interrupt) 
idle; 
if (ISR ! = 20h) 
error; 
else /* DMA end */ 
MR2 = 04h; 


Target Send /* DATA IN PHASE */ 


Program DMA controller; 


TCR = Olh; /* phase */ 
ICR = 49h; /* MODE E */ 
MR2 = CAh; 
SDS = 0; /* Start DMA Send */ 
while (NOT interrupt) 
idle; 
if (ISR! = 20h) 
error; 
else { /* DMA end */ 
MR2 = 40h; 


Change phase as required; 
} 
j 


4.9 BLOCK MODE DMA TRANSFERS 


In Block Mode the DMA interface uses the DRQ, DACK, 
EOP and READY lines, DRQ is asserted once at the begin- 


DACK \ / 
EOP \ for :B 


FIGURE 4.8.2. Target Send DMA 
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4.0 Device Operation (Continued) 


ning of transfers and deasserted once DACK is received. 
DACK should be asserted continuously for the duration of 
all the transfer. EOP should be asserted during the last 
DMA byte signal when the next DMA byte transfers. The 
EASI asserts the READY signal when the next DMA byte 
should be transferred. As for non-block mode the End of 
DMA interrupt is just EOP in MODE N, but is a True End of 
DMA in MODE E. 


The block mode is intended for systems where the over- 
head of handing the system busses to and from the wP and 
DMA controller is too great. The block mode handshake is 
not necessarily faster than non-block (it may be) but the 
overall transfer rate is improved once the bus exchange 
overhead is removed. Of course the uP is prevented from 
executing for the whole DMA operation. 


If a phase mismatch occurs the READY signal is left in the 
inactive state. The DMA controller must hand back the bus 
to the »P and the inactive READY signal may need to be 
gated off. For more detail see Section 9. 


When performing DMA as an INITIATOR the EOP signal 
does not deassert ACK on the SCSI bus in MODE N. Firm- 
ware must determine when REQ is inactive after the last 
SCSI transfer then reset the MR2 DMA bit to deassert ACK. 
In MODE E the EASI correctly handles the deassertion of 
ACK after True End of DMA. 


Programming the EASI in block mode is the same as non- 
block mode except bit 7 in MR2 should also be set. 


4.10 PSEUDO DMA 


The system design can utilize EAS! DMA logic for non data 
transfers. This removes the need to poll REQ/ACK and pro- 
gram the assertion/deassertion of the handshake signal. 
The »P can emulate a DMA controller by asserting DACK 
and EOP signals. DRQ may be sampled by reading the 
BSR. In most cases the chip decode logic can be adapted 
to this use for little or no cost. See Section 9 for further 
details. 


4.11 HALTING A DMA OPERATION 


There are three ways to halt a DMA operation apart from a 
chip or SCSI reset. These methods are: EOP, phase mis- 
match and resetting the DMA MODE bit in MR2. 


4.11.1 End of Process 


EOP is asserted for a minimum period during the last DMA 
cycle. The EOP signal generates the End of DMA interrupt 
in MODE N, and enables the True End of DMA to occur later 
in MODE E. EOP does not cause the MR2 DMA mode bit to 
be reset. 


4.11.2 DMA Phase Mismatch 


lf a REQ goes active while there is a phase mismatch the 
DMA will be halted and an interrupt generated. The EASI 
will stop driving the SCSI bus when the mismatch occurs. A 
phase mismatch is when the TCR phase bits do not match 
the SCSI bus values. 


4.11.3 DMA Mode Bit 


If EOP is not used, the best method is to reset the MR2 
DMA Mode bit. This bit may be reset at any time, and should 
be reset after an End of DMA interrupt or a phase mismatch. 
Resetting the bit disables all DMA logic and thus should 
only be reset at the True End of DMA condition. Additional- 
ly, all DMA logic is reset, so this bit must be reset then set 
again to carry out the next DMA phase. 
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5.0 Interrupts 


5.1 OVERVIEW 


The EASI is intended to be used in an interrupt driven envi- 
ronment. MODE E has greatly enhanced the use of inter- 
rupts to relieve firmware overhead. This section describes 
the conditions for and use of each interrupt. Each descrip- 
tion explains MODE N then MODE E operation. 


Before individually describing each interrupt, an explanation 
of the use of interrupts is required. 


5.2 USING INTERRUPTS 


MODE N: In this mode interrupts are controlled by bits in 
MR2 if control is provided. Not all interrupts can be disabled 
under software control. When an interrupt occurs, both the 
BSR and CSD register must be read and analyzed to deter- 
mine the source of interrupt. Since status is NOT provided 
for each interrupt, great care should be exercised when de- 
termining the interrupt source. 


MODE E: In this mode every interrupt can be individually 
masked and enabled or disabled. In addition, when an inter- 
rupt occurs a single register (ISR) can be read to determine 
the source(s) of interrupt. An associated register (IMR) al- 
lows a mask bit to be set for each interrupt. Finally, the 
design of the logic prevents loss of interrupts occurring after 
the INT signal goes Active and before the Reset Parity/In- 
terrupt function. In MODE N loss of interrupts can occur. 


5.3 SCSI PARITY ERROR 


MODE N: If SCSI parity checking is enabled via MR2 bit 5, 
an interrupt can occur as a result of a read from CSD, a 
selection/(re)selection, or a DMA receive operation. The 
parity error bit (bit 5) in the BSR will be set if checking is 
enabled. An interrupt will occur if Enable Parity Interrupt (bit 
4) of MR2 is set. The interrupt is reset by reading HA 7. 
Following an interrupt the BSR and CSB should contain the 
values shown below. 


Bit 7 Bit 0 


EDMA DRQ SPER INT PHSM BSY ATN ACK 
BSR 


Bit 7 Bit 0 


po fa} x{x {xi xjo] x 


RST BSY REQ MSG C/D I/O SEL DBP 
CSB 


5.4 uP PARITY ERROR 
MODE N: pP parity is not available under this mode. 


MODE E: If bit 6 of the EMR is 1, uP parity will be checked 
on a write to the EASI via the »P or DMA controller. The 
parity polarity is determined by bit 5 of the EMR. If bit 6 of 
the IMR is zero, a uP parity error will set bit 6 of the ISR and 
cause an interrupt. The interrupt may be reset by writing 01 
to bits 2 and 1 of the EMR followed by any other pattern. 


5.5 END OF DMA 


MODE N: If EOP is asserted during a DMA transfer, bit 7 of 
the BSR will be set and an interrupt generated if bit 3 of 
MR2 is 1. EOP is recognized when EOP, DACK and either 
1OR or IOW are all simultaneously active for a minimum 
period. The interrupt may be reset by reading HA 7. Follow- 
ing an interrupt the BSR and CSB should contain the values 
shown below. 


H 
F 


5.0 Interrupts (Continued) 
Bit 7 Bit 0 


pat xi xirt xi xtol x 


EDMA DRQ SPER INT PHSM BSY ATN ACK 
BSR 


Bit 7 Bit 0 


ERR ESE SESE 
RST BSY REQ MSG C/D I/O SEL DBP 
CSB 

5.6 DMA PHASE MISMATCH 


MODE N: When the SCSI REQ goes active during a DMA 
operation the contents of the TCR are compared with the 
SCSI phase lines C/D, MSG and I/O. If the two do not 


match an interrupt is generated. This interrupt will occur as. 


long as the MR2 DMA bit is set (bit 1), i.e., it cannot be 
masked in MODE N. The mismatch removes the EASI from 
driving the SCSI data bus. The interrupt may reset by read- 
ing HA 7. Following an interrupt the BSR and CSB should 
contain the values shown below. 


Bit 7 Bit 0 


PACE AeA EASES 


EDMA DRQ SPER INT PHSM BSY ATN ACK 
BSR 


Bit 7 Bit 0 


po tx} x} xi xixiot x 


RST BSY REQ MSG C/D I/O SEL DBP 
CSB 


MODE E: Bit 4 of the ISR will be set by a DMA phase mis- 
match—the same conditions as MODE N. The interrupt and 
setting if ISR bit 4 may be masked by setting bit 4 of the 
IMR. The interrupt may be reset by writing 01 to bits 2 and 1 
of the EMR followed by any other pattern. 


5.7 ANY PHASE MISMATCH 
MODE N: This feature is not available under this mode. 


MODE E: This condition is similar to DMA Phase Mismatch 
except that it applies to all operations—not just DMA. If the 
TCR contents do not match the SCS! phase lines when 
REQ goes active an interrupt is generated and bit 3 set in 
the ISR. The ISR bit and the interrupt may be masked by 
setting bit 3 in the IMR. The interrupt may be reset by writing 
01 to bits 2 and 1 of the EMR followed by any other pattern. 


5.8 BUSY LOSS 

MODE N: If bit 2 in MR2 is set the SCSI BSY signal is 
monitored and an interrupt is generated if BSY is continu- 
ously inactive for at least a BUS SETTLE DELAY (400 ns). 
This interrupt may be reset by reading HA 7. Following an 
interrupt the BSR and CSB should contain the values shown 
below, where usually CSB = 00. 


Bit 7 Bit 0 


EDMA DRQ SPER INT PHSM BSY ATN ACK 
BSR 
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RST BSY REQ MSG C/D 1/0 SEL BP 
CSB 


MODE E: Bit 2 in MR2 performs the same function as in 
MODE N. When an interrupt is generated bit 2 in the ISR will 
be set. The ISR bit and the interrupt may be masked by 
setting bit 2 in the IMR. The interrupt may be reset by writing 
01 to bits 2 and 1 of the EMR followed by any other pattern. 


5.9 (RE)SELECTION 


MODE N: An interrupt will be generated when: SEL is active, 
BSY is inactive, and the device ID is true. The device ID is 
determined by the value in the SER. If ANY non-zero bit in 
the SER has its corresponding SCSI data bit active during 
selection, the device ID is true. If I/O is active this is a rese- 
lection. The interrupt is disabled by writing all zeroes to the 
SER, and reset by reading HA 7. 


lf SCSI parity checking is enabled it will be checked and 
should be valid. Following an interrupt the BSR and CSB 
should contain the values shown below. 


Bit 7 Bit 0 


EG TOO | se 0 eo 


EDMA DRQ SPER INT PHSM BSY ATN ACK 
BSR 


Bit 7 Bit 0 


[ese ff iG, fe-20 So jf 0, Io a 


RST BSY REQ MSG C/D 1/0 SEL _ DBP 
CSB 


MODE E: The functioning of the (re)selection logic is the 
same as for MODE N. Additionally, bit 1 in the ISR will be 
set upon a (re)selection interrupt. The interrupt and setting 
of bit 1 in the ISR may be masked by setting bit 1 in the IMR. 
The interrupt may be reset by writing all zeroes to the SER 
then writing 01 to bits 2 and 1 of the EMR followed by any 
other pattern. 


5.10 ARBITRATION COMPLETE 
MODE N: No interrupt is generated in MODE N. 


MODE E: When bit 0 of the EMR is set to 1 the EASI moni- 
tors BSY and SEL to determine a BUS FREE Phase. The 
EASI then carries out all steps required for bus arbitration. 
When either arbitration is lost or the arbitration process has 
completed, bit 0 in the ISR is set and an interrupt generated. 
The interrupt and bit 0 in the ISR can be masked by setting 
bit O in the IMR. Note that arbitration is not affected by the 
IMR, just the interrupt. 


6.0 Reset Conditions 


6.1 GENERAL 
There are three ways to reset the EASI; wP chip RESET, 


SCSI bus reset applied externally, SCSI bus reset issued by 
the EASI. 


6.2 CHIP RESET 


When the RESET signal is asserted for the required dura- 
tion the EASI clears ALL internal registers and therefore 
resets all logic. This action does not create an interrupt or 
generate a SCSI reset. Since all registers contain zeroes, 
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6.0 Reset Conditions (Continued) 


the EASI is in MODE N under any of the three reset condi- 
tions. 


6.3 EXTERNAL SCSI RESET 


When an SCSI RST is applied externally the EASI resets all 
registers and logic and issues an interrupt. The only register 
bits not affected are the Assert RST bit (bit 7) in the ICR and 
the TARGET Mode bit (bit 6) in MR2. Note that the ISR will 
contain all zeroes. 


6.4 SCSI RESET ISSUED 


When the pP sets the Assert RST bit in the ICR, the RST 
signal goes active. Since the EASI monitors RST also, the 
same reset actions as in 6.2 apply. The SCSI RST signal will 
remain active as long as bit 7 in the ICR is set—i.e., until 
programmed 0 or a chip RESET occurs. 


7.0 Loopback Testing 


7.1 GENERAL 


The DP8490 EASI features loopback testing, enabled by bit 
3 of the EMR. When the LOOP bit is set in the EMR all SCSI 
drivers are disabled at the pads and the signals looped back 
internally. Additionally, both TARGET and INITIATOR sig- 
nals may be simultaneously asserted—this is not possible in 
normal operation. All this enables testing of EAS! operation 
without affecting the SCSI bus. . 


7.2 SCSI SIGNAL DRIVING/MONITORING 


Since each SCSI signal is looped back, testing is accom- 
plished by asserting a signal via the ICR or TCR, then read- 
ing back via CSB and BSR to check its state. The code 
below provides examples. The first example tests SCSI con- 
trol signals and the second the SCSI data bus. Note that 
loopback mode must be enabled prior to asserting any sig- 
nals if they are not to drive the SCSI bus. 


SCSI_signal_test 
{ 


ICR = 40h; /* MODE E */ 

EMR = 08h; /* LOOPback */ 

ICR = 5Eh; /* drive INIT controls */ 
TCR = OFh; /* drive TARG controls */ 


if((CSB==7Eh) AND (BSR==0Fh) ) 
ok; 
else error; 


j 


SCSI_data_test. 
{ 


ICR = 40h; /* MODE E */ 

EMR = 08h; /* LOOPback */ 

ICR = 41h; /* assert data bus */ 

MR2 = 30h; /* parity check & interrupt */ 
ODR = OAAh; 

if(CSD==OAAh) ok; 

else error; 

ODR = 55h; 

if(CSD==55h) ok; 

else error; 

if(interrupt)error; /* no parity errors */ 
else ok; 
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7.3 (RE)SELECTION AND ARBITRATION 


Both these features may be tested in loopback. Note that 
when checking BSY via the CSB register the ‘‘debounced” 
version of BSY is presented and will be active for 400 ns— 
800 ns after BSY goes inactive. Logic within the EAS! con- 
tinuously monitors BSY when it becomes inactive to detect 
a valid Bus Free Phase. One of the outputs of this logic is a 
clean version of BSY which is accessed through the CSB. 


7.4 DATA TRANSFERS 


Both programmed-I/O and DMA transfers may be per- 
formed. When doing DMA transfers the MR2 TARGET 
MODE bit (6) must be programmed according to the type of 
DMA—i.e., set to 1 for TARGET Send or Receive, reset to 0 
for INITIATOR Send or Receive. Additionally, the actions of 
the other SCSI device must be programmed. For example, 
when testing INITIATOR operations the BSY signal must be 
set via ICR to simulate a TARGET connected, and the REQ 
signal must be programmed active and inactive to perform 
the handshake. The code below shows a single byte trans- 
fer as INITIATOR Send. 


DMA_test 
{ 


program DMA controller; 


ICR = 40h; /* MODE E */ 

EMR = 08h; /* LOOPback */ 

ICR = 49h; /* BSY & data bus on */ 
MR2 = OAh; /* DMA & EOP interrupt */ 
TCR = 08h; /* assert REQ */ 

SDS = 0; /* Start DMA Send */- 
/* DMA cycle with EOP is done here */ 
ICR = 03 /* deassert REQ */ 
if(IDR==data byte) ok; 

else error; 

if(BSR==90h) ok; 

else error; 


/* also Should be an EOP interrupt */ 
} 


8.0 Extra Features/Compatibility 


8.1 OPERATING MODES 


This section is intended to clearly indentify the differences 
between the DP8490 and DP5380. The description covers 
registers, signals, timing, “bugs’’ and enhancements. For a 
more detailed description of register programming and bit 
functions refer to Sections 3-7. 


Before discussing differences a review of DP8490 operation 
is required. The EASI can be operated in two modes—Nor- 
mal Mode (MODE N) and Enhanced Mode (MODE E). The 
EASI is in one or the other mode at any time. MODE E is 
selected when bit 6 in the INITIATOR COMMAND REGIS- 
TER (ICR) is set to 1. A SCSI or external chip reset clears all 
registers (except MODE REGISTER 2 bit 6) so MODE N is 
selected as the default. MODE N may also be selected at 
any time by clearing bit 6 of the ICR to zero. If MODE E 
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8.0 Extra Features/Compatibility (continued) 


functions have been invoked, selecting MODE N does not in 
general affect their operation. This means MODE E is used 
to enable selection of enhanced features which can be used 
in either mode. Normally an application will choose to re- 
main in MODE E always since all functions are accessible in 
this mode. MODE N is only required for downward compati- 
bility with a standard 5380 device. The DP5380 operates 
ONLY in MODE N. 


The MODE selection via bit 6 of the ICR enables existing 
5380 firmware to run unaltered with the EASI. On the 5380 
this is a TEST MODE bit which disables ALL output driv- 
ers—NOTHING ELSE! No logic is “‘tested” and no changes 
are made to internal logic. Since the »P data bus drivers are 
also disabled the internal state of the 5380 is inaccessible. 
This means the TEST MODE bit has very limited application 
for the end user. By comparison the LOOPBACK bit in the 
EASI enables thorough testing of device operation. 


In summary, current operating firmware should not be using 
bit 6 of the ICR so the DP8490 uses this bit to enable en- 
hanced operation. As /ong as this bit is not set in the EAS/ 
the DP8490 appears the same as the NCR, AMD or 
DP5380. Programming, device operation, and timing se- 
guences are all the same as a 5380. 


8.2 INTERNAL REGISTERS 


Figure 8.1 shows the register map of the EASI. Note that in 
MODE N hex address 7 (HA 7) causes a Parity/Interrupt 
Reset when read and a Start DMA Initiator Receive when 
written. In MODE E the read/write EXTRA MODE REGIS- 
TER (EMR) is mapped into HA 7. Since the two original 
functions at HA 7 would conflict, their functions are repro- 


duced by writing to bits 1 and 2 of the EMR. This removes - 


any need to switch between modes. The INTERRUPT 
MASK REGISTER (IMR) and the INTERRUPT STATUS 
REGISTER (ISR) are accessed indirectly via the EMR. Set- 
ting both bits 1 and 2 of the EMR to 1 enables the next read 
of address 7 to access the ISR or the next write to access 
the IMR. Once the access is made subsequent uses of ad- 
dress 7 use the EMR. 


Read Write 
Register Register 


+ Current SCSI Data Output Data Register 
Initiator Command Initiator Command 
Mode Register 2 Mode Register 2 
Target Command. Target Command 
Current SCSI Bus Status | Select Enable Register 
Bus and Status Start DMA Send 
Input Data Register Start DMA Targ Rx 
Reset Parity/Interrupt Start DMA Init Rx 

(MODE N) (MODE N) 
Extra Mode Register Extra Mode Register 
(MODEE) | (MODE E) 
Interrupt Status Reg Interrupt Mask Reg 
(MODE E and bits 1 (MODE E and bits 1 


and 2 of EMR= 1) and 2 of EMR= 1) 
FIGURE 8.1. EASI Register Map 


8.3 ENHANCEMENT MODE REGISTERS 


MODE E provides three new registers to provide control for 
the extra features of the EASI. The EXTRA MODE REGIS- 
TER (EMR) is a read/write register which enables or dis- 
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ables the extra functions. Setting an EMR bit to 1 enables 
the corresponding function while programming a 0 disables 
it. Note on power-up or reset the EMR is zeroed so all extra 
functions are disabled. The INTERRUPT MASK REGISTER 
(IMR) provides the ability to individually mask out interrupts. 
The INTERRUPT STATUS REGISTER (ISR) shows the 
status of the interrupt system at any time. When an interrupt 
occurs the ISR will contain 1’s for interrupts that are active, 
enabled and not masked. Figure 8.2 shows the format of the 
three registers. 


8.4 EMR FEATURES 


8.4.1 Arbitration 


In MODE N, arbitration is enabled via bit 0 of MR2. However 
this requires polling the device for potentially many millisec- 
onds. The pP polls the ICR for the ARBITRATION IN 
PROGRESS bit (6) which is set once the ASI/EASI detects 
a bus free phase and enters arbitration. The ~P must then 
wait for the 2.2 ws ARBITRATION DELAY before checking 
IDs on the bus. No interrupt is given for any of these events. 


In MODE E, EASI arbitration is enabled by bit 0 of either 
MR2 or EMR. The EMR bit enables extended arbitration. 
The EASI will wait for bus free, arbitrate, wait the 2.2 ys 
ARBITRATION DELAY and the INTERRUPT the pP if not 
masked in the IMR. An interrupt occurs if arbitration is com- 
plete or has been lost. This feature removes the need to poll 
the EASI. 


7 ENHANCED MODE REGISTER 0 


Extended 
Arbitration 


00 = NOP 

01 = Reset Parity /Int 
10 = Start DMA Init Rx 
11=Rd/Wr ISR/IMR 


Loopback Mode 
SCSI Parity (ODD/EVEN) 
mP Parity (ODD/EVEN) 

BP Parity Enable 


Interrupt on any Phase Mismatch 
TL/F/9387-9 


7 INTERRUPT MASK/STATUS REGISTER 0 


Arbitration 
Complete 


(Re)Selection 
Busy Loss 

Any Phase Mismatch 

DMA Phase Mismatch 

DMA End 

BP Parity Error 


SCSI Parity Error 
TL/F/9387-10 
FIGURE 8.2. MODE E Registers 
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8.0 Extra Features/ vompateny (Continued) 


8.4.2 Loopback Mode 


When bit 3 is set in the EMR the EASI disables all SCSI 
drivers and loops back the Sy SEL ATH ST UG Out 
MSG, REQ and ACK outputs are fed back to their own in- 
puts. This enables testing of EASI operations, including 
DMA. 


8.4.3 scsi Parity 


SCSI parity may be enabled and ais Cause an interrupt (or 
be masked). Bit 4 of the EMR allows the polarity of SCSI 
parity to be set to either ODD or EVEN, with a default of 
ODD. This feature allows checking of SCS! devices and ca- 
ble. It also allows an INITIATOR to automatically detect 
whether a device SPP parity. (Send a parity error and 
check it is reported). 


8.4.4 uP Parity 


The EASI includes parity for the »P data bus. This enables 
controllers to validate data while it passes through their data 
buffers. In common with SCSI parity the uP parity may be: 
enabled/disabled, interrupt or be masked, be EVEN or ODD 
polarity. | 


8.4.5 Phase Mismatch 


In MODE N the EASI will only give a Phase Mismatch inter- 
rupt during DMA (normally data) transfers. In MODE E an 
interrupt can also be programmed for a phase mismatch 
during any phase. The mismatch is detected if REQ is active 
and the phase lines do not match the phase expected as 
specified in the TCR bits 0 to 2. This feature allows com- 
pletely interrupt-driven operation of the EASI. 


8.5 INTERRUPTS 


The EASI has an improved interrupt structure to ease pro- 
gramming. In MODE N the structure is the same as a stan- 
dard 5380. In this mode interrupts can occur which may only 
be determined by the lack of other interrupts (e.g., Selection 
and Phase Mismatch). Interrupts can also be missed if they 
occur while servicing others. To determine the cause of an 
interrupt requires reading the BSR and CSB registers then 
interpreting the results, knowing what the 5380 was current- 
ly doing. 

in MODE E interrupts can be individually masked via the 
IMR and active ones determined by reading the ISR. Any 
unmasked interrupts sets an ISR bit to 1. After the interrupt 
service routine the P should perform a Reset Parity/Inter- 
rupt function via the EMR—this will ONLY RESET interrupts 
which had a 1 in the ISR when it was last read. This feature 
means interrupts will not be lost. . 


8.6 TIMING 


The NCR5380 timing has some aspects which have been 
improved for MODE E of the EASI. In MODE N timing de- 
tails are the same as the 5380. Of course the DP5380 ASI 
remains the same as the NCR5380. The timing improve- 
ments are listed below. 


1. True End of DMA: In MODE N the end of DMA is when 
the last byte is transferred by the DMA controller, not 
when the final SCS! transfer is done. In MODE E bit’7 of 
the TCR shows a true end of DMA status—i.e., the last 
byte transferred by the later of the two events. This bit is 

' compatible with the NCR CMOS 53C80. 
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2. SCSI Handshake after EOP: in MODE N, INITIATOR re- 
ceive when a REQ is received after EOP has been given 
an ACK will be generated although no valid data exists 
since no DRQ was issued. The EASI will NOT generate 
this invalid ACK while in MODE E. 


wP and DMA accesses have relaxed timing on both the 
EAS! and ASI. Data setup/hold and read access times are 
reduced. Faster handshaking on the SCSI bus, along with 
faster response to the DMA signals means that higher 
transfer rates are possible with both devices—typically over 
3 MBytes/s. 


9.0 Application Guide 


This section is intended to show the interface between the 
pP, EASI and DMA.controller (DMAC). Figure 9.7 shows a 
general interface when the EASI and DMAC are |/O- 
mapped devices. This configuration will implement a 2 to 
2.5 MBytes/s SCSI port using 2 cycle compressed timing 
from the 5 MHz DMAC. | 


Using a faster DMAC and memory may allow the EASI to 
operate at a higher rate—but of course any system will be 
limited by the available DMA rate from the SCSI device cur- 
rently connected to. The interface shown has several fea- 
tures that are examined more closely in the following text. 


All the interface signal requirements are satisfied by a PAL 
device. The memory interface is not shown, only the rele- 
vant DMAC and pP lines are included. 


The EAS! data and address lines connect directly to the 
».P/DMAC busses. The DRQ output from the EASI goes 
direct to the DMAC. The EOP output from the DMAC goes 
to the EASI input, via the PAL, but can also be asserted via 
the PAL since the DMAC output is open-drain. 


The PAL is programmed so that the wP can access the 
EASI in three ways. The three access types are: Register 
R/W, DMA R/W, DMA with EOP. Examination of the PAL 
equations below shows how the pP may perform any of the 
three basic access types simply by accessing the EASI at 
different |/O address slots. This enables the uP to simulate 
a DMAC (pseudo-DMA). DMA mode may then be used for 
all information transfer phases. 


In DMA mode the EASI generates all SCSI handshakes. At 
all other times the pP is responsible for REQ/ACK hand- 
shakes. Using pseudo-DMA may reduce uP overhead. 


When doing DMA transfers via BLOCK MODE and an error 
occurs, the EASI may not deassert the READY signal. For. 
some DMA controllers this may lock the bus, so the PAL 
asserts READY and EOP to the DMA if an interrupt occurs 
while READY is false. This completes.the current DMA cy- 
cle and prevents further DMA for the rest of the block thus 
allowing the bus to be handed back to the wP for servicing. 
The PAL generates IOR and IOW strobes. while the pP is 
bus master, but the DMAC provides the strobes while it is 
bus master so the PAL outputs are TRI-STATE. 

The PAL details are shown in Figure 9.2 with the signal 
definitions and equations following. 


oO 
) | 9.0 Application Guide (continued) |@ 
: © 
t LP Interface © 
f 
q 
TL/F/9387—-11 
FIGURE 9.1. ».P/EASI/DMA Interface 
a CES 
AG ~>—~" EAS! 
AS EDACK 
ip Ad EEOP 
lORQ 
RD 
pied NSC PAL scce! 
' WR 20.10 DEOP 
: CSDMA 
AEN DREADY 
: DMAC DDACK IOR DMAC 
‘ on 
i EREADY 
, met ANT 
\ TL/F/9387~12 
‘ FIGURE 9.2. Interface PAL 
ip 
" 
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9.0 Application Guide (Continued) 


/CSEASI = /IORQ*/A7* /A6* /A5* /A4* /AEN 
/EDACK = /IORQ*/A7*/A6*/A5* A4*/RD 
/TORQ* /A7* /AG*/A5* A4*/WR 
+/TORQ*/A7*/AG* A5*/A4*/RD 
+/TORQ*/A7*/A6* A5* A4*/WR 
+/DDACK 
/EEOP = /IORQ*/A7*/A6* A5*/A4* /RD* /AEN 
+/IORQ*/A7*/AG6* A5*/A4* /WR* /AEN 
+/DEOP*EREADY 


EASI reg R/W chip select 
pP pseudo=DMA cycle 


we we 


pP pseudo=-DMA with EOP 


_ we 


DMAC DMA cycle 
w@P pseudo=-DMA with EOP 


we we 


Prevents EASI from seeing 
EOP until READY goes high. 


IF (/DDACK* /EREADY*INT) /DEOP = /DDACK*/EREADY*INT; on error this will terminate the DMA 
transfer. 


/CSDMA = /IORQ*/A7*/AG*A5*A4 
/DREADY = /EREADY*/INT 


we we 


DMAC register R/W 
EASI not READY and not INT 


+/EREADY* /DDACK EASI not READY and DMA cycle active 
IF(/AEN) /IOR = /IORQ*/RD pP I/0 Read cycle 
IF(/AEN) /IOW = /IORQ*/WR wP I/O Write cycle 


/EASIWR = /IORQ* WR*/AEN+/IOW*EREADY*AEN Prevents SCSI data being 
changed before EASI is 


READY for next byte. 
FIGURE 9.3. PAL Equations 


we ee we we we we we we 


The uP and DMA signals are defined below 


A7-A4 Address bus 

IORQ Memory I/O cycle select 

RD Read Strobe 

WR Write Strobe 

AEN High DMA address enable asserted by DMAC 
DDACK DMAC DMA Acknowledge 

CSDMA DMA Chip Select 

DREADY Ready signal to DMAC— inserts wait-states when low 
1OR, |OW \/O data strobes to/from DMAC 

EASIWR EASI write strobe. 
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10.0 Absolute Maximum Ratings* 

If Military/Aerospace specified devices are required, 
please contact the National Semiconductor Sales 
Office/Distributors for availability and specifications. 
Supply Voltage (Vcc) —0.5V to +7.0V 
DC Input Voltage (Vin) —0.5V to Voc + 0.5V 


DC Output Voltage (VoyT) —0.5V to Voc + 0.5V 
Storage Temperature Range (Tsta) —65°C to + 150°C 
Power Dissipation (Pp) 500 mW 
Lead Temperature (T,) 

(Soldering, 10 seconds) 260°C 
Electro-Static Discharge Rating 2kV 


*Absolute maximum ratings are those values beyond which damage to the device may occur. 


11.0 DC Electrical Characteristics 


Ta = 0°C to +70°C, Voc = 5.0V +5% unless otherwise specified 


Symbol Units 
Vin Minimum High Level 20 Vv 
Input Voltage 
ViL Maximum Low Level 
V 
Input Voltage 
Vout Minimum High Level . liout| = 20 pA Veco — 0.1 V 
VoH2 Output Voltage llourl = 4.0 mA 2.4 V 
Vout Maximum Low Level SCSI Bus Pins: |lo,| = 48 mA 4 0.5 V 
Vote Output Voltage Other Pins: |Io,| = 20 pA 0.1 V 
VoL3 llo.| = 8.0 mA 0.4 V 
lIN Maximum Input Current Vin = Voc or GND PT pA 
loz Maximum TRI-STATE Output Vout = Vcc or GND 
+10 pA 
Leakage Current 
loc Supply Current Vin = Voc or GND r aan 
SCSI Inputs = 3V 
Capacitance 1, = 25°C, f = 1 MHz 
V 
- S; (Note 2) 
te Rp =2.2k0 
AC Test Conditions Davee 
Input O Under O Output 


Input Pulse Levels GND to 3.0V 
Input Rise and Fall Time | 6s 
Input/Output Reference Levels 


TRI-STATE Reference Levels 
(Note 2) 


active high — 0.5V 


Note 1: C, = 50 pF including jig and scope capacitance. 


Note 2: S1 = Open for push-pull outputs. 
S1 = Vcc for active low to TRI-STATE. 
S1 = GND for active high to TRI-STATE. 


Note 3: This parameter is not 100% tested. 
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Test 


CL 
(Note 1) 


TL/F/9387-13 
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12.0 AC Electrical Characteristics 


All parameters are preliminary and subject to change without notice 


tye wa 


| Min 
bfas | _-BSYfalseto arbitrate start || _—1200_ 
bfbe | BSYfalsetobusclear | 
stbe | SELtetobusclear | 
rst RESET pulse width 


12.1 ARBITRATION 


SEL 


— 


stbe 


BSY 


=< 


bfas 
DBO..7 
bfbe 


BSY 


< 


12.2 uP RESET 


RESET i f 
rst 
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Units 


ns 
ns 
ns 


ns 


TL/F/9387-14 
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12.0 Electrical Characteristics 
12.3 uP WRITE 


AO..2 


12.4 .P READ 


AO..2 


as 


ww 


dsw 


rdv — 


csh 


dhw 


Eoin ahr 


ar 
ahw 
as 
osh 


dhw pP Data Hold Time from End of WR 


dsw Data Setup to End of Write Enable (no uP Parity) 
(Note 2) (with »P Parity) 


rdv Data Valid from Read Enable (Note 1) 


= 
ar 
a 
rere! 
-.. 
so 
7 
“a 


ww Write Enable Width (Note 2) 


Note 1: Read enable (uP) is CS and RD active. 
Note 2: Write enable (uP) is CS and WR active. 


DP8490 


TL/F/9387~16 


TL/F/9387-~17 


Units 


ns 
ns 
ns 
ns 
ns 
ns 


ns 
ns 


ns 


ns 


Note 3: This includes the RC delay inherent in the test’s method. These signals typically turn off after 25 ns, enabling other devices to drive these lines with no 


contention. 
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12.0 AC Electrical Characteristics (Continued) 
12.5 DMA WRITE (NON-BLOCK MODE) TARGET SEND 


DRQ 


DACK 


REQ 
ACK 


DBO.. 


dtdf dfdt 


EOP 


7,P 


: 


afrt 
atdt 
atrf 
dfdt 
dfrt 


dhwr | 


dkhw 
dsrt 
dswd 


dtdf 
eop 


wwn 


< 
xo) 


Data Setup to End of DMA Write Enable (no uP Parity) 
(Note 1) (with »P Parity) 


DACK True to DRO False | 
Width of EOP Pulse (Note 2) : 
DMA Non-block Mode Write Enable Width (Note 2) 40 


ol 


— 
oO 


30 
10 
0 


G & 
oi oO 


as 


~N “I 
on a = 


Note 1: Write enable (DMA) is DACK and WR active. 
Note 2: EOP, DACK, RD/WR must all be true for recognition of EOP. 
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Units 


ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 


ns 
ns 


ns 
ns 


ns 


12.0 AC Electrical Characteristics (Continued) 
12.6 DMA WRITE (NON-BLOCK MODE) INITIATOR SEND 


DRO d 
dtdf dfdt 


DACK 


WR ls 


(han dswd dhwr —> 


00.7 a 
: i} 
REQ ~ 
rtat dfaf—» 
ACK . 
dhi 
DBO..7,P Byte n F tti(‘i‘SCSYS Byte n+! 


[win [tye [oe 


dfat__ | DACKFalsetoACkFalse ||| 
diat_ || DACKFalsetoDRQTue || 
dri | SCSIDataHoldromwriteEnable-iniiator | 18 || 
dnwr__ | DMADataHoldTimetromEndofWR | tT 
dknw | DACKHoldtromEndofWR | 


dswd Data Setup to End of DMA Write Enable (no pP Parity) 
(Note 1) (with "oT" SE Parity) 


didf DACK True to | DACKTruetoDRQFalse sis False 


eop to Raa a SOOKE 
rt__—||—REQFalsetoDRQTue || 
at | REQTuetoacKTe Tt 
wun | ~DMAWriteEnablewidtn(Notet) | aT 


Note 1: Write enable (DMA) is DACK and WR active. 
Note 2: EOP, DACK, RD/WR must all be true for recognition of EOP. 
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Units 


ns 
ns 
ns 
ns 
ns 


ns 
ns 


ns 
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12.0 AC Electrical Characteristics (Continued) 
12.7 DMA READ (NON-BLOCK MODE) TARGET RECEIVE 


“DRO 


dtdf 
DACK 
RD 
ddv 


00.7 | 


eop 
EOP 
atdt 
REQ 
atrf 
ACK 
dsra dhra 


Symbol Parameter 


afrt ACK False to REQ True (DACK or WR False) 
atdt ACK True to DRQ True 

atrf ACK True to REQ False 

ddv DMA Data Valid from Read Enable (Note 1) 
dfdt DACK False to DRQ True 

dfrt DACK False to REQ True (ACK False) 

dhr Data Hold from End of Read Enable (Notes 1, 2) 
dhra ’ SCSI Data Hold from ACK True 

dkhr * DACK Hold from End of RD 

dsra SCSI Data Setup Time to ACK True 

dtdf DACK True to DRQ False 


- eop Width of EOP Pulse (Note 3) 
Note 1: Read enable (DMA) is DACK and RD active. 


— 
© 


dfdt 
dkhr 
dhr 
dfrt 


— afrt 


or 


N N“N 
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Units 


ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 


ns 


Note 2: This includes the RC delay inherent in the test’s method. These signals typically turn off after 25 ns enabling other devices to drive these lines with no 


contention. 
Note 3: EOP, DACK, RD/WR must all be true for recognition of EOP. 
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12.0 AC Electrical Characteristics (continued) 
12.8 DMA READ (NON-BLOCK MODE) INITIATOR RECEIVE 


0678dG 


DRQ 
| didf dfdt 
DACK 
dkhr 
RD 
ddv dhr 


~—_—__——- eop 


EOP 
rtdt rfaf 
REQ 
ACK , 
dsra dhra 


TL/F/9387-21 


Symbol Parameter _ hl Units 
| Min | tye | Max 

ddv DMA Data Valid from Read Enable (Note 1) a i a 
dfaf DACK False to ACK False (REQ False) i a 
aft DACK False to DRQ True | sx | om | | os 
dhr Data Hold from End of Read Enable (Notes 1, 2) | 20 dT ws ns 
dhra . SCSI Data Hold from REQ True Sa ae ns 
dkhr DACK Hold from End of RD Poo [Ud] Ys 
dsra SCSI Data Setup Time to REQ True eae ae ns 
ata DAK True to DRQ False a ae a 4 
eop Width of EOP Pulse (Note 3) ee ee ee ee 
rfaf REQ False to ACK False (DACK False) i a 
tat REQ True to ACK True as a ee 
rt REQ True to DRQ True i ees ee 


Note 1: Read enable (DMA) is DACK and RD active. 


Note 2: This includes the RC delay inherent in the test’s method. These signals typically turn off after 25 ns enabling other devices to drive these lines with no 
contention. 


Note 3: EOP, DACK, RD/WR must all be true for recognition of EOP. 
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12.0 AC Electrical Characteristics (Continued) 
12.9 DMA WRITE (BLOCK MODE) TARGET SEND 


DRQ 


dtdf 


DACK 


eop 
EOP 
REQ 
ACK 
READY 
DBO..7, P Byte n+#1 
afrt ACK False to REQ True (DACK or WR False) He fe 


at be Sel Oe I Ae 
art | ACKTuetoREADYTue | 8 
dhat___ | SOSIDataHoldtromackTue ||| 
dhwr___| _DMADataHoldTimefromEndofwa | to || 
det | _scSiDataSetuptoneQTue || 


dswd Data Setup to End of DMA Write Enable (no pP Parity) 
(Note 1) (with ,zP Parity) 


att |—DACKTruetoDRQFase =| T| 
eop | Width of EOPPulse(Note2) ||| 
rtwf READY True to WR False a a a 
wit | _WRFalsetoREADYFalse =| || 
wit | _WRFalsetoREQTrue(ACKFalse) ||| 8 
wwb | _DMAWriteEnable width (Note) =| 4 | | 


Note 1: Write enable (DMA) is DACK and WR active. 
Note 2: EOP, DACK, RD/WR must ail be true for recognition of EOP. 
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Units 


ns 
ns 
ns 
ns 
ns 
ns 


ns 
ns 


ns 
ns 
ns 
ns 
ns 


ns 


12.0 AC Electrical Characteristics (Continued) 
12.10 DMA WRITE (BLOCK MODE) INITIATOR SEND 
DRQ 
dtdf 
DACK 
wwb 
WR 
dswd dhwr 
00.7 a 
eop 
EOP | 3 
REQ 
wfaf 
ACK 
rtyt = rtwf wirf 
READY 
dhi 
DBO..7,P Byte n fF i (i‘CéiéCS?S Byte n#1 


TL/F/9387-23 


Symbol Parameter eee Units 
| min | typ | Max 

dhi SCSI Data Hold from Write Enable a ae rr a ns 

dhwr DMA Data Hold Time from End of WR a 


dswd Data Setup to End of DMA Write Enable (no pP Parity) or of ll ns 
| (Note 1) (with wP Parity) 35 ns 
|_atat | packtuetopRarase | | 
| eop | Width of EOPPulse(Notez) | ||| 
ryt | REQFalsetoREADYTue =| || 
rat | _“REQTuetoACKTue | | ts 
wi | READYTuetowRFalse | | | 
| 88 
| 50 
a 


ns 


wiaf WR False to ACK False (REQ False) ae ae ns 
wirf WR False to READY False aa ae 
ww DMA Write Enable Width (Note 1) : = a 


Note 1: Write enable (DMA) is DACK and WR active. 
Note 2: EOP, DACK, RD/WR must all be true for recognition of EOP. 


ns 


ns 


0678dd 
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12.0 AC Electrical Characteristics (continued) 
12.11 DMA WRITE (BLOCK MODE) TARGET RECEIVE 


DRQ 
dtdf 


ddv dhr 


eop 


rfrt 


REQ 


atrf afrt 


ACK 
READY 


Symbol Parameter click 


- - -& |; ol N 
oa; oa ao oOo }oO or 


afrt ACK False to REQ True (DACK or WR False) 

atrf ACK True to REQ False 100 
atyt ACK True to READY True dl 

ddv DMA Data Valid from Read Enable (Note 1) | 

dhr Data Hold from End of Read Enable (Notes 1,2) 


al 
ea 
a 
Mel 
ee 
dhra SCSI Data Hold from ACK True = eee 
dsra SCSI Data Setup Time to ACK True a a ae 
ai 
El 
aa 
ie 
lee esl 


dtdf DACK True to DRQ False ae 
eop Width of EOP Pulse (Note 3) | 25 
rfrt RD False to REQ True (ACK False) od 7 
rfyf RD False to READY False aa 
rydv READY True to Data Valid ted 


Note 1: Read enable (DMA) is DACK and RD active. 


TL/F/9387-24 
Units 


ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns | 


ns 


Note 2: This includes the RC delay inherent in the test’s method. These signals typically turn off after 25 ns enabling other devices to drive these lines with no 


contention. 
Note 3: EOP, DACK, RD/WR must all be active for recognition of EOP. 
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12.0 AC Electrical Characteristics (Continue) 
12.12 DMA READ (BLOCK MODE) INITIATOR RECEIVE 


DRQ 
dtdf 
DACK 
RD 
ddv dhr 
00.7 Sa 
. eop 
EOP | i | 
. rfaf 
REQ 
ACK A ie 
rydv ne rfyf 
rtyt 
READY 


dsra 


TL/F/9387-25 


| Min | typ | Max 
ddv__| DMADataValidfromReadEnabie(Noret) | || aon 
dnr_ | DataHoldtromEndofReadnabie Notes 2) | 20 | | 60s 
dha | —SCSiDetaHoldtomreaTue | ts || 
dea | —SCSiDataSetupTimetonEaTue | to || |r 
att | DACKTruetopR@rase | ||| 
ep | WidthofEOPPuse(Notes) | ts ||| 
riat____ | RDFalsetoACK False (REGFase) ||| tao | 
rat____ | REQFalsetoACKFalse(OAckFaise) | ||| 
ry’ | —RDFalsotoneADvFase | ||| 
rat | REQTwetoAcKTue || 
ryt | REQTwetoREADYTues | || 


Note 1: Read enable (DMA) is DACK and RD active. 


Note 2: This includes the RC delay inherent in the test’s method. These signals typically turn off after 25 ns enabling other devices to drive these lines with no 
contention. 


Note 3: EOP, DACK, RD/WR must all be active for recognition of EOP. 
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Appendix A1 


Arbitration & (Re)Selection 


ODR = device ID 


Set MR2 : ARB 
(bit 0) 


Check 


Wait BUS FREE + 
ARBITRATION Delays 
(800 +2200 a 


Reset 
MR2 ARB 


Check ICR LA 
(bit 5) 


Read CSD and resolve 
ID priorities 


This device 
ID is highest ? 


Yes 
Set ICR: ASS — SEL 
(bit 2) 


Wait BUSCLEAR + 
BUS SETTLE delays 
(800 + 400 ns) 


Device is a 
Target 


Yes = | Reselection 


Set MR2: TARGET 
MODE (Bit 6) 
Set TCR: ASS_I/0 
(bit 0) 


ICR AIP a 


(bit 6) Reset 


(Normal Mode) 
y 


ODR = device 
1D OR'd 
with controller 


SELECTION < > RESELECTION 


‘ Set ICR: DBUS, Set ICR : DBUS, 
ATN, SEL (Bits 0,1,2) SEL (Bits 0,1) 


Ensure SER=0 
Reset MR2: ARB 
(Bit 0) 


BSY active 
within SELECTION 
TIMEOUT DELAY 
(250 ms) 


No 


Yes 


SELECTION < > RESELECTION 
Reset ICR: DBUS, SEL Set ICR: BSY (Bit 3) 
(Bits 0,2) 


Set ICR: DBUS, 
SEL (Bits 0,2) 


Information 
Transfer Phases 


TL/F/9387-27 
*Only set ATN if Select with ATN is desired. 


No = Selection 


TL/F/9387-26 
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Appendix A\1 (Continued) 


Arbitration & (Re)Selection (Enhanced Mode) 


ODR = device ID 
Set EMR: ARB 
(bit 0) 

Do other tasks while 
waiting for interrupt 


(Interrupt) 


Reset 
EMR: ARB 


Read ISR, check ARB 
Complete (Bit 0) is set 
Set EMR: EFN=01 
(Bits 2,1) to reset interrupt 
Set EMR: EFN=00 to 
remove interrupt reset 


Read CSD and resolve 
priorities 


This device 
is highest 
? 


Yes 
Set ICR: ASS_SEL 
(bit 2) 


Wait BUS CLEAR + 
BUS SETTLE delays 
(800 + 400 ns) 


Set MR2 : TARGET 
MODE (Bit 6) 
Set TCR: ASS_I/0 
(bit 0) 
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No= Selection 
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Appendix A1 (Continued) 


Command Transfer (initiator) 


Set MR2:BSY(bit 2) 
Set TCR:C/D (bit 1) 


ODR = Command byte 
Set ICR : Asset_ACK 
(bit 4) 


0 


Reset ICR : ASS_ACK 
(bit 4) 
More bytes 
? 


No 


Next Phase 
TL/F/9387-—29 


*This step unnecessary in MODE E if the EMR : 
APHS (bit 7) is enabled. Logic automatically 
checks the phase on any transfer and interrupts 


On an error. 
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Appendix A1 (Continued) 


Command Transfer (Target) 
=] 
Phase 
ATN active? 


BSR bit 1 


Set TCR:C/D (bit 1) 
Wait Bus Settle Delay 
Set TCR: ASS_REQ (bit 3) 
ACK ? 


(bit 0) 
1 


Command = CSD 
(Parity checked if enabled) 


Verify Operation Code 
setup CDB length 
Reset TCR: ASS_REQ 


as; ? 


(bit 0) 
0 


Transfer remaining 
CDB bytes 


TL/F/9387-30 
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Appendix A1 (Continued) 


Block Mode DMA Transfer 
Initiator Receive (MODE E) 


Program DMA Controller with block 
length, start address and memory 
write operation 


TCR = Oth; ICR= 40h; MR2=BEh 
EMR =04h to Start DMA 


oe 


Yes 


Read ISR for interrupt status 


Reset DMA Mode 
(MR2 = 04h) 


Error routine 


TL/F/9387-31 
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Block Mode DMA Transfer 
Target Send (MODE E) 


Program DMA Controller with block 
length, start address and memory 
write operation 


TCR = Oth; ICR = 39h; MR2=CAh 
SDS = XX to Start DMA Send 


or 


Yes 


Read ISR for interrupt status 


Reset DMA Mode 
(MR2 = 04h) 


Error routine 
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Appendix A2 


Register Chart 


Read 


Bit 7 Current SCSI Data (CSD) Bit 0 


Bit 7 Initiator Command Register (ICR) Bit 0 


Bit 7 Mode Register 2 (MR2) Bit 0 


BLK |TARG|PCHK] PINT | EOP | Bsy | DMA | ARB 


Bit 7 Target Command Register (TCR) 


.o | o | o | o | REG) wSG| C7 | 


Bit 7 Current SCSI Bus Status (CSB) Bit 0 


Fst | BSY | REG | WSG | C70 | 170 | SEL | DBP | 


Bit 7 Bus and Status Register (BSR) Bit 0 


[EDMa| DRG [SPER] INT [PHSm] Bsy | ATN | ACK 


Bit 7 input Data Register (IDR) Bit 0 


bar | bes | bas | bea | bes | Dae | Det | DBO 


Bit 0 
170 


Reset Parity/Interrupt 


Bit 7 (RP!)}—MODE N Bit 0 
Bit 7 Enhanced Mode Register (EMR) Bit 0 


APHS| MPEN| MPOL | SPOL| LOOP | EFN1 | EFNO| ARB 


Bit 7 Interrupt Status Register (ISR) Bit 0 


[SPE | MPE | EDMA | DPHS | APHS | BSY | SEL | ARB 


Target Command Register 
(TCR)—MODE E 


Bit 7 


Bit 0 


REQ | MSG | C/D 


X = Unknown 
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Write 


Bit 7 Output Data Register (ODR) Bit 0 


| ber | bee | bes | Ded | Des | Dee | Dat | DBO 


Bit 7 Initiator Command Register (ICR) Bit 0 
re | [a [oe |e aoa 


Bit 7 Mode Register 2 (MR2) Bit 0 


BLK |TARG|PCHK| PINT | EOP | Bsy | DMA | ARB | 


Bit 7 Target Command Register (TCR) Bit 0 


_x | x | x | x | ReG| wee] o70 | 70_ 


Bit 7 Select Enable Register (SER) Bit 0 


[oar [686 | ves | oe | oss | ose | 657 | Den 


Bit 7 Start DMA Send (SDS) Bit 0 


Start DMA Target Receive 


Bit 7 (SDT) Bit 0 


Start DMA Initiator Receive 
| (SDI)—MODE N 


Bit 7 Bit 0 


Bit 7 Enhanced Mode Register (EMR) Bit 0 


[APHS | MPEN| MPOL| SPOL| LOOP | EFN1 | EFNO] ARB 


Bit 7 Interrupt Mask Register (IMR) Bit 0 


[spe | MPE | epMA | DPHS | APHS | Bsy | SEL | ARB 


Target Command Register 
| (TCR)—MODE Bit 0 


Bit 7 


X = Don't Care 
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National 
Semiconductor 


DP5380 Asynchronous SCSI Interface (ASI) 


General Description 


The DP5380 ASI is a CMOS device designed to provide a 
low cost, high performance Small Computer Systems Inter- 
face. It complies with the ANS X3.131-1986 SCSI standard 
as defined by the ANSI X3T9.2 committee. It can act as 
both INITIATOR and TARGET, making it suitable for any 
application. The ASI supports selection, reselection, arbitra- 
tion and all other bus phases. High-current open-drain driv- 
ers on chip reduce application chip count by interfacing di- 
rect to the SCSI bus. An on-chip oscillator provides all tim- 
ing delays. 

The DP5380 is pin and program compatible with the NUOS 
NCR5380 device. NCR5380 or AM5380 applications can 
use it with no changes to hardware or software. The 
DP5380 is available in a 40-pin DIP or a 44-pin PCC. 


The ASI is intended to be used in a microprocessor based 
application, and achieves maximum performance with a 
DMA controller. The device is controlled by reading and 
writing several internal registers. A standard non-multi- 
plexed address and data bus easily fits any wP environment. 


Data transfers can be performed by programmed-|/O, pseu- 
do-DMA or via a DMA controller. The AS! easily interfaces 


Connection Diagram 


MPU SCSI 
BUS BUS 
00..7 DP5380 DBO..7,DBP 
AO RST 
At BSY 
A? = Asynchronous SEL 
SCSI Interface 
cs (ASI) ACK 
RD ATN 
WR 
RESET REQ 
(70 
INT c/D 
DRQ MSG 
DACK 
READY 
EOP - 
Vss = Vpp 
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to a DMA controller using normal or Block Mode. The ASI 
can be used in either a polled or interrupt-driven environ- 
ment. 


Features 


SCSI Interface 
m Supports TARGET and INITIATOR roles 
m@ Parity generation with optional checking 
@ Arbitration support 
m@ Direct control/monitoring of all SCSI signals 
@ High current outputs drive SCSI bus directly 
m@ Faster and improved timing 
mw Very low SCSI bus loading 


uP Interface 
Memory or |/O-mapped control transfers 
Programmed-!/O or DMA data transfers 
Normal or Block-mode DMA 
Fast DMA handshake timing 


Table of Contents 
1.0 FUNCTIONAL DESCRIPTION 
2.0 PIN DESCRIPTION 
3.0 REGISTER DESCRIPTION 
4.0 DEVICE OPERATION 
5.0 INTERRUPTS 
6.0 RESET CONDITIONS 
7.0 APPLICATION GUIDE 
8.0 ABSOLUTE MAXIMUM RATINGS 
9.0 DC ELECTRICAL CHARACTERISTICS 
10.0 AC ELECTRICAL CHARACTERISTICS 
Ai FLOWCHARTS 
A2 REGISTER CHART 
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1.0 Functional Description 


1.1 OVERVIEW 


The ASI is designed to be used as a peripheral device in a 
@P-based application and appears as a number of read/ 
write registers. Write registers are programmed to select de- 
sired functions. Status registers provide indication of operat- 
ing conditions. 


For best performance a DMA controller can be easily inter- 
faced directly to the ASI. The ASI provides request/ac- 
knowledge and wait-state signals for the DMA interface. 


The SCS! bus is easily controlled via the ASI registers. Any 
bus signal may be asserted or deasserted via a bit in the 
appropriate register, and the state of every signal is avail- 
able by reading registers. This direct control over SCSI sig- 
nals allows the user to implement all or part of the protocol 
in firmware. The ASI provides hardware support for much of 
the protocol. 


The ASI provides the following SCSI support: 


¢ Programmed-I/O transfers for all eight information trans- 
fer types, with or without parity. 


e Data transfers via DMA, in either block or non-block 
mode. The DMA interface supports most devices. 


Data Address 


SCSI 


BUS DP5380 


ASI 


Arbitration 
PAL 


ai Address 


Latch 


° Individual setting/resetting and monitoring of every SCSI 
bus signal. 


e Automatic release of the bus for BSY loss from a TAR- 
GET, SCSI RST, and lost arbitration. 


¢ Automatic bus arbitration—the uP has only to check for 
highest priority. 

© Selection or Reselection of any bus device. The ASI will 
respond to both Selection and Reselection. 


¢ Optional automatic monitoring of the BSY signal from a 
TARGET with an interrupt after releasing control of the 
bus. 


Figure 71 shows an ASI in a typical application, a low cost 
embedded SCSI! disk controller. In this application the 8051 
single-chip P acts as the controller and the dual DMA 
channels in the DP8475 allow one for the disk data and the 
other for SCS/ data. The PAL® provides chip selection as 
well as determining who has control of the bus. The advan- 
tao~ of using a »P with on-board ROM is that there is more 
fiee time on the external bus. 


DP8463 


2,7 Endec 


DP8466A 


Disk 
Controller 


DP8462 


PLL 


DP8468 


Pulse 
HPC1 6083 staal 
Embedded 
ne Servo {| 


Disk Drive Data 
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FIGURE 1. ASI Application 
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1.0 Functional Description (Continued) 


1.2 uP INTERFACE 


Figure 2 shows a block diagram of the ASI. Key blocks with- 
in the ASI are Read/Write registers with associated decode 
and control logic, interrupt and DMA logic, SCSI bus arbitra- 
tion logic, SCSI drivers/receivers with parity and the SCSI 
data input and output registers. The ASI! has three interfac- 
es, one to SCSI, one to a DMA controller and the third to a 
pP. The internal registers control all operations of the ASI. 


The pP interface consists of non-multiplexed address and 
data busses with associated control signals. Address de- 
code logic selects a register for reading or writing. The ad- 
dress lines AO-2 select the register for P accesses while 
for DMA accesses the address lines are ignored. 


The register bank consists of twelve registers mapped into 
an address space of eight locations. Upon an external chip 
reset the registers are cleared (all zeroes). 


1.3 DMA INTERFACE 


The DMA logic interfaces to single-cycle, block mode, flow- 
through or fly-by controllers. Single byte transfers are ac- 
complished via the DRQ/DACK handshake signals. Block 


RST BSY 


qf 


mode transfers use the READY output to control the speed 
(insert wait-states). An End Of Process (EOP) input from the 
DMA controller signals the ASI to halt DMA transfers. An 
interrupt can be generated for DMA completion or an error 
(see Section 5.0). All DMA data passes through the SCSI 
data input and output registers, automatically selected dur- 
ing DMA cycles. 


1.4 SCSI INTERFACE 


The ASI contains all logic required to interface directly to the 
SCSI bus. Direct control and monitoring of all SCSI signals 
is provided. The state of each SCSI signal may be deter- 
mined by reading a register which continuously reflects the 
state of the bus. Each signal may be asserted by writing a 
ONE to the appropriate bit. 


The ASI includes logic to automatically handle SCSI timing 
sequences too fast for wP control. In particular there is 
hardware support for DMA transfers, bus arbitration, selec- 
tion/reselection, bus phase monitoring, BSY monitoring for 
bus disconnection, bus reset and parity generation and 
checking. 


SEL ACK ATN REQ i/0 C/D MSG DBO..7,P 


High=Current SCSI Drivers & Receivers 


SCSI Interface 
Control Logic 


Data 
Output 


Data 
Input 
Register 


Register 


Tat | ap 
ESTE eae OES 
eI igi 


: Interrupt Control 
DMA Logic raale Registers 
pro! | READY INT 
EOP DACK 
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FIGURE 2. ASI Block Diagram 


1.0 Functional Description (continued) 


The ASI arbitration logic controls arbitration for use of the The ASI incorporates high-current drivers and SCHMITT 
SCSI bus. The »P programs the SCSI device ID into the trigger receivers for interfacing directly to the SCSI bus. This 
ASI, then sets the ARBITRATE bit. The INITIATOR COM- feature reduces the chip count of any SCSI application. 


MAND REGISTER (ICR) is read to determine when arbitra- 
tion has started and whether it is won or lost. 


The BSY signal is continously monitored to detect bus dis- 
connection and bus free phases. The ASI incorporates an 
on-board oscillator to determine Bus Settle, Bus Free and 
Arbitration Delays. The oscillator tolerance guarantees all 
timing to be within the SCSI specification. 


1.5 PARITY 


The ASI provides for parity protection on the SCSI interface. 
The data bus has eight data bits and one parity bit. The 
parity may be enabled via a register bit. A parity error can be 
programmed to cause an interrupt. 


2.0 Pin Descriptions 


Symbol | pip | pce | Type | Function 


cs Chip Select: an active low enable for read or write operations, accessing the register 
selected by AO... 2. 


AO...2 33, 36, 37 Address 0... 2: these three signals are used with CS, RD, and WR to address a 
register for read or write. 

RD 27 Read: an active low enable for reading an internal register selected by AO...2and 
enabled by CS. It also selects the Input Data Register when used with DACK. 

WR Write: an active low enable for writing an internal register selected by AO... 2 and 
enabled by CS. It also selects the Output Data Register when used with DACK. 

RESET 31 Reset: an active low input with a Schmitt trigger. Clears all internal registers. (SCSI 
RST unaffected). 

DO...7 | 1,40-34 | 2, 44-38 I/O | Data0...7: bidirectional TRI-STATE® signals connecting the active high P data 
bus to the internal registers. 

INT Interrupt: an active high output to the .P when an error has occurred, an event 
requires service or has completed. 

DRO DMA Request: an active high output asserted when the data register is ready to read 
or written. DRQ occurs only if DMA mode is enabled. The signal is cleared by DACK. 

DACK DMA Acknowledge: an active low input that resets DRQ and addresses the data 
registers for input or output transfers. DACK is used instead of cS by the DMA 
controller. 

READY Ready: an active high output used to control the speed of block mode DMA transfers. 
Ready goes active when the chip is ready to send/receive data and remains inactive 
after the transfer until the byte is sent or until the DMA mode bit is reset. 

EOP End Of Process: an active low signal that terminates a block of DMA transfers. It 
should be asserted during the transfer of the last byte. 

aed I/O | DBO... 7, DBP: SCSI data bus with parity. DB7 is the MSB and is the highest priority 
during arbitration. Parity is ODD. Parity is always generated and canbe optionally 
checked. Parity is not valid during arbitration. 

RST el ee Reset: SCS/ reset, monitored and can be set by ASI. 

BSY I/O | Busy: indicates the SCSI bus is being used. Can be driven by TARGET or 
INITIATOR. 

SEL ae Me bad Select: used by the INITIATOR to select a TARGET or by the TARGET to reselect an 
INITIATOR. 


ACK 1/0 Acknowledge: driven by the INITIATOR and received by the TARGET as pa of the 
REQ/ACK handshake. 
T 1/O | Attention: driven by the INITIATOR to indicate an attention condition to the _ 
TARGET. 


> 
= 
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2.0 Pin Descriptions (Continued) 


2.1 Connection Diagrams 


| 2] 3] 8 SI 
PF 
8 


n 
[ae | 
pe 


DB5 _—«d0B7 D2 D4 


Function 


Request: driven by the TARGET and received by the INITIATOR as-part of the REQ/ 
ACK handshake. 


Input/Output: driven by the TARGET to control the direction of transfers on the 
SCSI bus. This signal also distinguishes between selection and reselection. 


Command/Data: driven by the TARGET to indicate whether command or data bytes 
are being transferred. 


Message: driven by the TARGET during message phase to identify message bytes 
on the bus. 


VCC, GND: + 5V DC is required. Because of very large switching currents good 
decoupling and power distribution is mandatory. 


Order Number DP5380N 
See NS Package Number N40A 
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Order Number DP5380V 
See NS Package Number V44A 


18 19 20 21 22 23 24 25 26 27 28 


RTS REG 
76 se FQ 


CS —sINT _ READY 
pro «RD 
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3.0 Register Description 


3.1 GENERAL 


The DP5380 ASI is a register-based device with eight ad- 
dressable locations. Some addresses have dual functions 
depending upon whether they are being read from or written 
to. Device operation is described in Section 4. 


Figure 3.2 summarises the register map. Note that for regis- 
ters reading or writing SCSI signals the SCSI name is used 
for each bit. Although the SCSI bus is active low the regis- 
ters invert the SCSI bus. This means an active SCSI signal 
is represented by a ONE in a register and an inactive signal 
by a ZERO. 


3.2 REGISTERS 
OUTPUT DATA REGISTER (ODR) 
8 Bits HA 0 Write-Only 


This is a transparent latch used to send data to the SCSI 
bus. The register can be written by pP cycles or via DMA. 
DMA writes automatically select the ODR at Hex Address 0 
(HA 0). This register is also written with the ID bits required 
during arbitration and selection/reselection phases. Data is 
latched at the end of the write cycle. 


Bit 7 Bit 0 
[os ss [os [os] os sr | os 
Output Data Register 

CURRENT SCSI DATA (CSD) 
8 Bits HA 0 Read-Only 


This register enables reading of the current SCSI data bus. 
If SCSI parity checking is enabled it will be checked at the 
beginning of the read cycle. The register is also used for P 
accesses of SCSI data during programmed-I/O or ID check- 
ing during arbitration. Parity is not valid during arbitration. 
DMA transfers select the IDR (HA 6) instead of the CSD 
register. 


Bit 7 


| [| | | [| 


Current SCSI Data 


Bit 0 


os 


INITIATOR COMMAND REGISTER (ICR) 
8 Bits HA 1 Read-Write 


This register is used to control the INITIATOR and some 
other SCSI signals, and to monitor the progress of bus arbi- 
tration. Most of the SCSI signals may also be asserted in 
TARGET mode. Bits 5 to 0 are reset when BSY is lost (see 
MR2 description). 


Bit 7 Bit 0 


sr |v [| er oe 


Initiator Command Register 


DBUS: Assert Data Bus 
0 Disable SCSI data bus driving. 


1 Enable contents of Output Data Register onto the SCSI 
data bus. SCSI parity is also generated and driven on 
DBP. 


This bit should be set when transferring data out of the ASI 
in either TARGET or INITIATOR mode, for both DMA or 
programmed-I/O. In INITIATOR mode the drivers are only 
enabled if: Mode Register 2 TARGET MODE bit is 0, and 
170 is false, and C/D, 170, MSG match the contents of the 
Target Command Register (phasematch is true). In TAR- 
GET mode only the MR2 bit needs to be set with this bit. 


Reading the ICR reflects the state of this bit. 
ATN: Assert Attention 
0 Deassert ATN. - 


1 Assert SCSI ATN signal. The MR2 TARGET MODE bit 
must also be false to assert the signal. 


Reading the ICR reflects the state of this bit. 
SEL: Assert Select 
O Deassert SEL. 


1 Assert SCSI SEL signal. Can be used in INITIATOR or 
TARGET mode. 


Reading the ICR reflects the state of this bit. 
BSY: Assert Busy 
0 Deassert BSY. 


1 Assert SCSI BSY signal. Can be used in INITIATOR or 
TARGET mode. 


Reading the ICR reflects the state of this bit. 


Bit 0 


Bit 1 


Bit 2 


Bit 3 


i a 
0 Output Data Register 8 WO 
0 Current SCSI Data 8 RO 
1 Initator Command Register 8. RW 
2 Mode Register 2 8 RW 
3 Target Command Register 4 RW 
4 Select Enable Register 8 WwO 
4 Current SCSI Bus Status 8 RO 
5 Bus and Status 8 RO 
5 Start DMA Send a?) WO 
6 Start DMA Target Receive 0 WO 
6 Input Data Register 8 RO 
7 Start DMA Initiator Receive 0 wo 
7 Reset Parity/Interrupts 0 RO 


FIGURE 3.2. Registers 
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3.0 Register Description (Continued) 
ACK: Assert Acknowledge Bit 4 
0 Deassert ACK. 


1 Assert SCSI ACK signal. The MR2 TARGET MODE bit 
must also be false to assert the signal. 


Reading the ICR reflects the state of this bit. 

DIFF: Differential Enable Bit5 Write 

0 This bit must be reset to 0. 

1 Do not use. Reserved for future use on a differential 


pair device. 

LA: Lost Arbitration Bit5 Read 

0 Normally reset to 0 to show arbitration not lost or not 
enabled. 


ot, 


Will be set when the ASI loses arbitation, i.e. when SEL 
is true during arbitration AND the Assert SEL bit of this 
register is false. 


A 1 in this bit means the ASI has arbitrated for the bus, 


asserted BSY and its ID on the data bus and another device 
has asserted SEL. The ARBITRATE bit in MR2 must be set 
to enable arbitration. 


TEST: Test Mode Enable Bit6 Write 
0 Output drivers are enabled. 

1 Output drivers disabled. 

AIP: Arbitration In Progress Bit6é Read 


0 Normally 0 to show no arbitration in progress. 


1 Set when the ASI has detected BUS FREE phase and 
asserted BSY and the Output Data Register contents 
onto the SCSI data bus. This bit remains set until arbi- 
tration is disabled. 


RST: Assert RST 
0 Deassert RST. 


1 Assert SCSI RST signal. RST is asserted as long as this 
bit is 1, or until a wP Reset (RESET). 


After this bit is set the INT pin goes active and internal regis- 
ters reset (except for the interrupt latch, MR2 TARGET 
MODE bit, and this bit. Reading the ICR reflects the state of 
this bit. 


MODE REGISTER 2 (MR2) 
8 Bits HA2 Read-Write 


This register is used to program basic operating conditions 
in the ASI. Operation as TARGET or INITIATOR, DMA 
mode and type as well as some interrupt controls are set via 
this register. This is a Read/Write register and when read 
the value reflects the state of each bit. 


Bit 7 


Bit 7 Bit 0 


sx [ve er] or [sn] 


Mode Register 2 


ARB: Arbitrate 
0 Disable arbitration. 


1 Enable arbitration. The ASI will wait for a BUS FREE 
phase then arbitrate for the bus. Before setting this bit 


Bit 0 
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the Output Data Register should contain the SCSI de- 
vice |D—a single bit set only. The status of the arbitra- 
tion process is given in the AIP and LA bits (6, 5) in the 
Initiator Command Register. 

DMA: DMA Mode 

0 Disable DMA mode. 

1 Enable DMA operation. This bit should be set then one 
of address 5 to 7 written to start DMA. The TARGET 
MODE bit in the ICR and the phase lines in the TCR 
should have been set appropriately. The DBUS bit in 
the ICR must be set for DMA operations. BSY must be 
active in order to set this bit. The phase lines must 
match the contents of the TCR during the actual trans- 
fers. In DMA mode ASI logic automatically controls the 
REQ/ACK handshakes. 

This bit should be reset by a P write to stop any DMA 
transfer. An EOP signal will not reset this bit. During 
DMA, CS and DACK should not be active simultaneous- 
ly. 

This bit will be reset if BSY is lost during DMA mode. 

BSY: Monitor Busy Bit 2 

0 Disable BSY monitor. 

1. Monitor SCSI BSY signal and interrupt when BSY goes 
inactive. When this bit goes active the lower 6 bits of 
the ICR are reset and all signals removed from the 
SCSI bus. This is used to check for valid TARGET con- 
nection. 


Bit 1 


EOP: Enable EOP Interrupt Bit 3 
0 No interrupt for EOP. 

1 Interrupt after valid EOP condition. 

PINT: Enable SCSI Parity Interrupt Bit 4 


0 No interrupt on SCSI parity error. 


1 When SCSI parity is enabled via the PCHK bit, setting 
this bit enables an interrupt upon a SCSI parity error. 


PCHK: Enable SCSI Parity Checking Bit 5 
0 No SCSI parity checking. 


1 Enable checking of SCSI parity during read operations. 
This applies to either programmed |/O or DMA mode. 


TARG: Target Mode Bit 6 
0 Initiator Mode. 

1 Target Mode. 

BLK: Block Mode DMA Bit 7 


0 Non-block DMA. 


1 When set along with DMA bit (1) enable block mode 
DMA transfers. In block mode the READY line is used 
to handshake each byte with the DMA controller in- 
stead of the DRQ/DACK handshake used in non-block 


mode. | 
TARGET COMMAND REGISTER (TCR) 
4 Bits HA 3 Read-Write 


This register is used to control TARGET SCSI signals and to 
program the desired phase during INITIATOR mode. During 


3.0 Register Description (Continued) 


DMA transfers the SCSI phase lines (C/D, MSG, I70) must 
match the contents of the TCR for transfers to occur. A 
phase mismatch halts DMA transfers and generates an in- 
terrupt. 


Bit 7 Bit 0 


[Ts [= [= [mma] ro 
Target Command Register 


This is a read/write register and the value read reflects the 

state of each bit, except bit 4-7 which always read 0. 

1/0: Assert 170 Bit 0 

0 Deassert 1/0. 

1 Assert SCSI 170 signal. The MR2 TARGET MODE bit 
must also be active. 

C/D: Assert C/D 

0 Deassert C/D. 

1 Assert SCSI C/D signal. The MR2 TARGET MODE bit 
must also be active. 

MSG: Assert MSG 

0 Deassert MSG. 

1 Assert SCSI MSG signal. The MR2 TARGET MODE bit 
must also be active. 

REQ: Assert REQ 

0 Deassert REQ. 

1 Assert SCSI REQ signal. The MR2 TARGET MODE bit 
must also be active. This bit is used to handshake SCSI 
data via programmed-!/O. 

SELECT ENABLE REGISTER (SER) 

8 Bits HA 4 Write-Only 

This write-only register is used to program the SCSI device 

ID for the ASI to respond to during Selection or Reselection 

Phases. Only one bit in the register should be set. When 

SEL is true, BSY false and the SER ID bit active an interrupt 

will occur. 

This interrupt is reset or can be disabled by writing zero to 

this register. Parity will also be checked during Selection or 

Reselection if the PCHK bit in MR2 is set. 


Bit 1 
Bit 2 


Bit 3 


Bit 7 Bit 0 


sr | ||| | i [ 


Select Enable Register 


CURRENT SCSI BUS STATUS (CSB) 
8 Bits HA 4 Read-Only 


This read-only register is used to monitor SCSI control sig- 
nals and the SCSI parity bit. The SCSI lines are monitored 
during programmed-I/O transfers and after an interrupt in 
order to determine the cause. A bit is 1 if the corresponding 
SCSI signal is active. 


Bit 7 Bit 0 


[esr] ea | we | oo] | 


Current SCSI Bus Status 


4-49 


BUS AND STATUS REGISTER (BSR) 

8 Bits HA 5 Read-Only 

This read-only register is used to monitor SCSI signals not 
included in the CSB, and internal status bits. This register is 
read after an interrupt to determine the cause of an inter- 
rupt. Bit O or 1 are set to 1 if the SCSI signal is active. 


Bit 7 Bit 0 


cu] vo oo [ror [ace 


Bus & Status Register 


ACK: Acknowledge Bit 0 

This bit reflects the state of the SCSI ACK Signal. 

ATN: Attention Bit 1 

This bit reflects the state of the SCSI ATN Signal. 

BSY: Busy Error Bit 2 

0 No Error. 

1 This SCSI BSY signal has become inactive while the 
MR2 BSY (Monitor BSY) bit is set. This will cause an 
interrupt, remove all ASI signals from the SCSI bus and 
reset the DMA MODE bit in MR2. 

PHSM: Phase Match Bit 3 

0 Phase Match. The SCSI C/D, I/O and MSG phase lines 
are continuously compared with the corresponding bits 
in the TCR. The result of this comparison is reflected in 
this bit. This bit must be 1 (phase matches) for DMA 
transfers. A phase mismatch will stop DMA transfers 
and cause an interrupt. 

INT: Interrupt Request 

0 No Interrupt. 

1 Interrupt request active. Set when an enabled interrupt 
condition occurs. This bit reflects the state of the INT 
pin. INT may be reset by performing a Reset Parity/In- 
terrupt (RPI) function. 

SPER: SCSI Parity Error 

0 No SCSI parity error. 

1 SCSI parity error occurred. This bit remains set once an 
error occurs until the RPI function clears it. The PCHK 
bit in MR2 must be set for a parity error to be checked 
and registered. 

DRQ: DMA Request 

0 No DMA request. 

1 DMA request active. This bit reflects the state of the 
DRQ pin. DRQ is reset by asserting DACK during a 
DMA cycle or by resetting the DMA bit in MR2. A Busy 
error will reset the MR2 DMA bit and thus will also clear 
DRQ. A phase mismatch will not reset DRQ. 

EDMA: End of DMA Bit 7 

0 Not end of DMA. 

1 Set when DACK, EOP and either RD or WR are active 
simultaneously. Normally occurs when the last byte is 
transferred by the DMA. During DMA send operations 
the last byte transferred by the DMA may not have 
been transferred on SCSI so REQ and ACK should be 
monitored to verify when the last SCSI transfer is com- 
plete. This bit is reset when the MR2 DMA bit is reset. 


Bit 4 


Bit 5 


Bit 6 
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3.0 Register Description (Continue) 


START DMA SEND (SDS) 
0 Bits HA 5 Write-Only 


This write-only register is used to start a DMA send opera- 
tion. A write of don’t-care data should be the last thing done 
by the uP. The MR2 DMA, BLK and TARG bits must have 
been programmed previously. 


Bit 7 Bit 0 


Start DMA Send 


START DMA TARGET RECEIVE (SDT) 
0 Bits HA 6 Write-Only 


This write-only register is used to start a DMA Target Re- 
ceive operation. Same comments as SDS apply. 


INPUT DATA REGISTER (IDR) 
8 Bits HA 6 Read-Only 


This read-only register contains the SCSI data last latched 
during a DMA receive. Each byte from SCSI is latched into 
this register automatically by the ASI DMA logic. A DMA 
read (DACK and RD) automatically selects this register. Pro- 
grammed-|I/O SCSI data reads should use the CSD (HA8) 
START DMA INITIATOR RECEIVE (SDI) 

0 Bits HA 7 Write-Only 

This write-only register is used to start a DMA INITIATOR 
Receive Operation. Same comments as SDS apply. 
RESET PARITY/INTERRUPT (RPI) 

0 Bits HA 7 Read-Only 

This read-only register is used to reset the parity and inter- 
rupt latches. Reading this register resets the SCSI parity, 
Busy Loss and Interrupt Request latches. 


4.0 Device Operation 


4.1 GENERAL 


This section describes overall operation of the ASI. More 
detailed information of data transfers, interrupts and reset 
conditions are covered in later sections. The operation de- 
scription covers 4P accesses, SCSI bus monitoring, arbitra- 
tion, selection, reselection, programmed-|/O, DMA inter- 
rupts. Programming and timing details are covered. 


For information regarding interfacing to P’s and DMA con- 
trollers refer to Section 7.0. 


In the descriptions following program examples are given in 
pseudo-C. This processor-independent approach should be 
clearest. These are backed up by flow charts in Appendix 
A.1. 


4.2 uP ACCESSES 


The »P accesses the EASI via the CS, RD, WR and address 
and data lines in order to read/write the registers. Figure 4.2 
shows typical timing. Note the use of non-multiplexed ad- 
dress and data lines. 


4.3 SCSI BUS MONITORING/DRIVING 


The SCSI bus may be monitored or driven at any time. Each 
bus signal is buffered and inverted by the ASI and can be 
read via the CSB, BSR and CSD registers. An active SCS] 
reads a 1 in the status registers. 
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DO..7 (Read) 


)  : 
i) STAATEED, 


FIGURE 4.2. P Cycles 


Each SCSI signal may be asserted by setting a bit in the 
TCR or ICR. Setting the bit to 1 asserts the SCS! signal. 
The following code demonstrates a byte transferred via pro- 
grammed-!/O in INITIATOR mode. 


DO..7 (Write) 
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{ /*Transfer one byte as Initiator*/ 
while (NOT (TCR:REQ) ) ; 
/* wait till TARGET asserts REQ */ 
data = input (CSD); 
/* parity is checked if enabled*/ 
output (ICR, Assert ACK) ; 
while (TCR:REQ) ; 
/* wait till TARGET deasserts REQ */ 
output (ICR, 0) 3 
/* deassert ACK, ready for next byte */ 
} 


4.4 ARBITRATION 


This sub-section describes the arbitration support provided 
by the ASI and how to program it. 


Since the SCSI arbitration process requires signal sequenc- 
ing too fast for »P’s, hardware support is provided by the 
ASI. The arbitration process is enabled by bit O MR2 (ARB). 
Prior to setting this bit the ODR should be programmed with 
the device’s SCS! ID—a single bit. 


The ASI will monitor the bus for a BUS FREE phase. The 
BSY signal is continuously monitored. If continuously inac- 
tive for at least a SCSI Bus Settle Delay (400 ns) and SEL is 
inactive, a valid Bus Free Phase exists. After a period of 
SCSI Bus Free Delay (800 ns) the ASI asserts BSY and the 
ODR onto the SCSI data bus. The ~P should poll the ICR to 
determine when arbitration has started. The AIP bit in the 
ICR is set when the Bus Free Phase is detected and the 
EASI is beginning the Bus Free Delay. Following the Bus 
Free Delay a 2.2 ps SCSI Arbitration Delay is required be- 
fore examining the data bus to resolve the priorities of the 
ID bits. This delay must be implemented in firmware. The 
ICR Lost Arbitration (LA) bit must be examined to determine 
whether arbitration is lost. The LA bit is set if another 


4.0 Device Operation (Continued) 


device asserts SEL during arbitration. If the LA bit is 0 the 
data bus is read via the CSD register. The data is examined 
to resolve ID priorities. If this device is the highest ID assert 
SEL by setting ICR bit 2 to a 1. After waiting Bus Clear + 
Bus Settle Delays (1200 ns) the Selection Phase begins. 
These 2 delays must be implemented in firmware. 


4.5 SELECTION/RESELECTION 


The ASI can be used to select or reselect a device. The ASI 
will also respond to selection or reselection. 


4.5.1 Selecting/Reselecting 


Selection requires programming the ODR with the desired 
and own device ID’s; the data bus via ICR DBUS (bit 0); 
asserting ATN if required via ICR bit 1; asserting SEL via 
ICR bit 2; then resetting the MR2 ARB bit. 


The SER should have been cleared to zero before Selec- 
tion/Reselection to ensure the ASI does not respond. If Re- 
selection is desired the I7O line should also be asserted 
before SEL via TCR bit 0. 


Resetting the ARB bit causes the ASI to remove BSY and 
the ODR from the data bus. Thus the ICR Assert data bus 
bit is required to assert the bits for desired and own device 
ID’s. 

BSY is then monitored to determine when the device has 
responded to (re)selection. If the device fails to respond an 
error handler should sequence the ASI off the bus. If the 
device responds the ICR DBUS and SEL bits should be re- 
set to remove these signals. If this is a Reselection the ICR 
BSY bit (3) should be set before removing the other signals. 


The bus is now ready to handle Information Transfer Phas- 
es. 


4.5.2 (Re)Selection Response 


The ASI responds to Selection or Reselection when the 
SER is non-zero. A (re)selected interrupt is generated when 
BSY is false for at least a Bus Settle Delay (400 ns); and 
SEL is true AND any non-zero bit in the SER has its corre- 
sponding SCSI data bus bit active. A Selection is disabled 
by zeroing the SER. If parity is supported it should be valid 
during (re)selection so must be checked via the SPE bit (5) 
in the BSR. SCSI specification states that (re)selection is 
not valid if more than 2 data bits are active. This condition is 
checked by reading the CSD. 


When the selection interrupt occurs it is determined by read- 
ing the BSR and CSB registers. There is no dedicated 
status bit for (re)selection so it must be determined by the 
absence of other interrupts, and the active state of the SEL 
signal. Reselection occurs when 1/0 is also active. See 
Section 6.0. 


4.6 MONITORING BSY 

While an INITIATOR is connected to a TARGET the TAR- 
GET must maintain an active BSY signal. During DMA oper- 
ations the BSY signal is monitored by the ASI and will halt 
operations if it goes inactive. To enable BSY to be moni- 
tored at other times the MR2 BSY bit (2) should be set. An 
interrupt will be generated if BSY goes inactive while MR2 
BSY is set. 


This interrupt sets bit 2 in the BSR. 


4.7 COMMAND/MESSAGE/STATUS TRANSFERS 


Command message and status bytes are transferred using 
programmed-|/O. The SCS! REQ/ACK handshake is ac- 
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complished by monitoring and setting lines individually. Data 
is output via the ODR and read in via the CSD register. 


The following code shows INITIATOR and TARGET pro- 
gramming for two of these cases. See Appendix A.1 for 
flowcharts. 


Initiator Command Send 
{ 
MR2 = monitor BSY 
TCR = Command Phase /*02h*/ 
while (bytes) to do) { 
while (REQ) inactive) 
idle; /*CSB bit 5 = 0*/ 


if (BSR: phase match == 0) 
phase error; 
else { 


ODR = date byte; 
ICR = Assert ACK; 
while (REQ active) 

idle; /*CSB bit 5 == 1*/ 
ICR = deassert ACK 
/* byte transfer complete */ 
byte count =-=-; 


} 
goto data phase; 
} 


Target Message Receive 


{ 


/* assumed Assert BSY already set in ICR */ 


MR2 = TARG MODE OR PARITY CHECK OR 
PARITY INTERRUPT ; 
TCR = Message Out phase; /*06h*/ 
delay (Bus Settle) ; 
TCR = Assert REQ; 
while (ACK inactive) 

idle; /* BSR bit 0 */ 
data = CSD; /* parity is latched */ 
if (BSR: parity error) 

error routine; 
else { 

TCR = deassert REQ; 

while (ACK active) 

idle; 


} 
/* message done, can change to next 
phase */ 
} 


4.8 NON-BLOCK DMA TRANSFERS 


Data transfers may be effected by DMA. This method 
should be used for optimum performance. Two methods of 
DMA are available-block and non-block mode. This section 
describes non-block mode transfers. 
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4.0 Device Operation (continued) 


The interface to the DMA controller uses the DRQ, DACK, 
EOP lines in non-block mode. Each byte is requested (DRQ) 
and ack’d (DACK). Representative timing for a DMA read is 
shown in Figure 4.8. 7. 


TL/F/9756-7 
FIGURE 4.8.1. Non-Block DMA Timing 


4.8.1. NON-BLOCK DMA 


DMA operation involves programming the ASI with the set- 
up parameters, initiating the DMA cycles and checking for 
correct operation when the completion interrupt is received. 
The DMA controller should be programmed with the data 
byte count and the memory start address. Methods of halt- 
ing a DMA operation are covered in Section 4.11. 


Setting up the ASI requires enabling or disabling the follow- 
ing: Data bus driving, DMA mode enable, BSY monitoring, 
EOP interrupt, parity checking, parity interrupt, TARGET 
Mode, bus phase. 


Once set up DMA should be initiated by writing to address 5, 
6, or 7 as appropriate. The DMA controller should assert 
EOP during the transfer of the last byte, although this may 
be done by the uP if the DMA transfers (n — 1) bytes and 
the »P transfers the last byte. See the application guide for 
more details (Section 7.0). 


Upon completion the uP should check the following as re- 
quired: End of DMA, Parity Error, Phase Match, Busy Error. 
The end of DMA occurs as a response to EOP. SCSI trans- 
fers may still be underway so REQ and ACK must still be 
checked to establish when the final byte is finished. 


The code below shows programming of the ASI in each of 
the four DMA cases. One of these cases is shown in a flow 
diagram in Appendix A. 


Initiator Send 
{ 


/*DATA OUT PHASE*/ 


Program DMA Controller; 


TCR = OOh; /*phase*/ 
ICR = Olh; /*Assert_DBUS*/ 
MR2 = OEh: 
SDS = 00; /*Start DMA Send*/ 
while (NOT interrupt) | 
idle; 
while (CSD :REQ) 
idle /*wait for last 


SCSI byte 
transfer so phase 
is checked*/ 
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if(BSR:Busy error OR NOT 
(BSR :End_of_DMA) ) 
error routine; 


else { /*DMA End*/ 
MR2 = 04h; /*reset DMA bit*/ 
ICR = 0; 


Initiator Receive 


{ 


/*DATA IN PHASE*/ 


Program DMA Controller; 


TCR = Olh; /*phase*/ 

MR2 = 3Eh; 

SDI = 0; /*Start DMA Init 
Rx* / 

while (NOT interrupt) 


idle; 


/*no need to wait for last SCSI handshake 
done since DMA done implies it is 
checked*/ 


if(BSRsparity_error OR BSR: busy -error 
or NOT (BSR End of DMA) 
do error routines; 
else { 
while (CSD:REQ) 
idle; /*wait for REQ inactive 
to deassert ACK*/ 
= 04h; 


/*End of DMA*/ 


Target Receive 


/*DATA OUT PHASE*/ 


Program DMA Controller; 


ICR = 0; /*phase*/ 

ICR = 08h; 

MR2 = 7Ah; /*check parity*/ 

SDT = 0; /*Start DMA Targ Rx*/ 
while (not interrupt) 


idle; 
/*when End of DMA occurs the last byte 
has been read and checked*/ 
if(BSR:parity_error OR NOT(BSR: End_of_DMA) 
error routine; 
{ else 
while (BSR:ACK) 
idle; 
/*Not True End of DMA, so wait until SCSI 
bus inactive before changing phase*/ 
MR2 = 40h; 
change phase as required ; 


/*End of DMA*/ 


oe a Se SS 


4.0 Device Operation (Continued) 
Target Send /*DATA IN PHASE*/ 


{ 
Program DMA Controller; 


TCR = Olh; /*phase*/ 
ICR = 09h; 
MR2 = 4Ah; 
SDS = 03 /*Start DMA Send*/ 
while (NOT interrupt) 
idle; 
if (NOT (BSR :End_of_DMA) 
error; 
else { /*DMA end*/ 
repeat { 


while (CSB:REQ OR BSR:ACK) 
loop count = 3; 

loop count -=-;} /*decrement*/ 
until (loop count == 0); 

MR2 = 40h; 

Change phase as required; 


j 


Some explanation of the final part of Target Send is re- 
quired. In this type of DMA operation it is very difficult to 
exactly determine the True End of DMA simply detecting 
REQ and ACK simultaneously inactive is not enough. 


Reference to Figure 4.8.2 will help to understand the follow- 
ing text. 


REQ Byte n=1 Byte n 


TL/F/9756-8 
FIGURE 4.8.2. Target Send DMA 


As shown in Figure 4.8.2 ACK going active causes the DRQ 
for the next byte and also REQ to go inactive. ACK going 
inactive allows REQ to go active for the next byte. If the 
INITIATOR is slow removing ACK the »P may sample the 
SCSI bus after the EOP interrupt at point A. Here both REQ 
and ACK will be inactive, but there is one more byte to 
transfer on SCSI. Due to chip timing delays this condition 
will not last more than 200 ns. A safe way to determine the 
True End of DMA is to sample REQ and ACK and ONLY 
when both are inactive in three successive samples will the 
pP be at point B in the figure. 
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4.9 BLOCK MODE DMA TRANSFERS 


In Block Mode the DMA interface uses the DRQ, DACK, 
EOP and READY lines, DRQ is asserted once at the begin- 
ning of transfers and deasserted once DACK is received. 
DACK should be asserted continuously for the duration of 
all the transfer. EOP should be asserted during the last 
DMA byte signal when the next DMA byte transfers. The 
ASI asserts the READY signal when the next DMA byte 
should be transferred. 


As for non-block mode the End of DMA interrupt is just 
EOP, also in block mode receive the ASI does not return 
READY to an active signal after EOP. This means external 
logic must gate off READY if the uP is not to be locked up. 
For more details see Section 7.0. 


The block mode is intended for systems where the over- 
head of handing the system busses to and from the wP and 
DMA controller is too great. The block mode handshake is 
not necessarily faster than non-block (it may be) but the 
overall transfer rate is improved once the bus exchange 
overhead is removed. Of course the »P is prevented from 
executing for the whole DMA operation. 


If a phase mismatch occurs the READY signal is left in the 
inactive state. The DMA controller must hand back the bus 
to the pP and the inactive READY signal may need to be 
gated off. 


When performing DMA as an INITIATOR the EOP signal 
does not deassert ACK on the SCSI bus. Firmware must 
determine when REQ is inactive after the last SCSI transfer 
then reset the MR2 DMA bit to deassert ACK. 


Programming the ASI in block mode is the same as non- 
block mode except bit 7 in MR2 should also be set. 


4.10 PSEUDO DMA 


The system design can utilize ASI DMA logic for non-data 
transfers. This removes the need to poll REQ/ACK and pro- 
gram the assertion/deassertion of the handshake signal. 
The »P can emulate a DMA controller by asserting DACK 
and EOP signals. DRQ may be sampled by reading the 
BSR. In most cases the chip decode logic can be adapted 
to this use for little or no cost. See Section 7.0 for further 
details. 


4.11 HALTING A DMA OPERATION 


There are three ways to halt a DMA operation apart from a 
chip or SCSI reset. These methods are: EOP, phase mis- 
match and resetting the DMA MODE bit in MR2. 


4.11.1 End Of Process 


EOP is asserted for a minimum period during the last DMA 
cycle. The EOP signal generates the End of DMA interrupt. 
EOP does not cause the MR2 DMA mode bit to be reset. 


4.11.2 DMA Phase Mismatch 


If a REQ goes active while there is a phase mismatch the 
DMA will be halted and an interrupt generated. The ASI will 
stop driving the SCSI bus when the mismatch occurs. A 
phase mismatch is when the TCR phase bits do not match 
the SCS! bus values. 


4.11.3 DMA Mode Bit 


if EOP is not used the best method is to reset the MR2 DMA 
Mode bit. This bit may be reset at any time, and should be 
reset after an End of DMA interrupt or a phase mismatch. 
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4.0 Device Operation (Continued) 


Resetting the bit disables all DMA logic and thus should 
only be reset at the True End of DMA condition. Additionally 
all DMA logic is reset so this bit must be reset then set again 
to carry out the next DMA phase. 


5.0 Interrupts 


5.1 OVERVIEW 


Before individually describing each interrupt an explanation 
of the use of interrupts is required. 


5.2 USING INTERRUPTS 


Interrupts are controlled by bits in MR2 if control is provided. 
Not all interrupts can be disabled under software control. 
When an interrupt occurs both the BSR and CSD register 
must be read and analysed to determine the source of inter- 
rupt. Since status is NOT provided for each interrupt great 
care should be exercised when determining the interrupt 
source. | 


5.3 SCSI PARITY ERROR 


If SCSI parity checking is enabled via MR2 bit 5 an interrupt 
can occur as a result of a read from CSD, a selection/ 
(re)selection, or a DMA receive operation. The parity error 
bit (bit 5) in the BSR will be set if checking is enabled. An 
interrupt will occur if Enable Parity Interrupt (bit 4) of MR2 is 
set. The interrupt is reset by reading HA7. Following an in- 
terrupt the BSR and CSD should contain the values shown 
below. | 


Bit 7 Bit 0 


EDMA DRQ SPER INT PHSM BSY ATN ACK 
| | BSR 


Bit 7 : Bit 0 


RST BSY REQ MSG C/D 1/0 SEL DBP 
CSD 


5.4 END OF DMA 


If EOP is asserted during a DMA transfer bit 7 of the BSR 
will be set and an interrupt generated if bit 3 of MR2 is 1. 
EOP is recognized when EOP, DACK and either IOR or OW 
are all simultaneously active for a minimum period. The in- 
terrupt may be reset by reading HA 7. Following an interrupt 
the BSR and CSD should contain the values shown below. 


t 


Bit 7 Bit 0 


sda} fits] [ots 


EDMA DRQ SPER INT PHSM BSY ATN ACK 
BSR 
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RST BSY RE SG 
CS 


5.5 DMA PHASE MISMATCH 


When the SCSI REQ goes active during a DMA operation 
the contents of the TCR are compared with the SCS! phase 
lines C/D, MSG and I/O. If the two do not match an inter- 
rupt is generated. This interrupt will occur as long as the 
MR2 DMA bit is set (bit 1), i.e. it cannot be masked. The 
mismatch removes the ASI from driving the SCSI data bus. 
The interrupt may reset by reading HA 7. Following an inter- 
rupt the BSR and CSD should contain the values shown 
below. 


Bit 7 Bit 0 


EDMA DRQ SPER INT PHSM BSY ATN ACK 
BSR 


Bit 7 Bit 0 


RST BSY REQ MSG C/D 170 SEL DBP 
CSD 


5.6 BUSY LOSS 


If bit 2 MR2 is set the SCSI BSY signal is monitored and an 
interrupt is generated if BSY is continuously inactive for at 
least a BUS SETTLE DELAY (400 ns). This interrupt may be 
reset by reading HA 7. Following an interrupt the BSR and 
CSD should contain the values shown below, where usually 
CSD = 00. 


Bit 7 Bit 0 


EDMA DRQ SPER INT PHSM BSY ATN ACK 
BSR 


Bit 7 Bit 0 


RST BSY REQ MSG C/D 1/0 SEL DBP 
CSD 


5.7 (RE)SELECTION 


An interrupt will be generated when: SEL is active, BSY is 
inactive, and the device ID is true. The device ID is deter- 
mined by the value in the SER. If ANY non-zero bit in the 
SER has its corresponding SCS! data bit active during se- 
lection the device ID is true. If I/O is active this is a reselec- 
tion. The interrupt is disabled by writing all zeros to the SER, 
and reset by reading HA 7. 


5.0 Interrupts (Continued) 
lf SCSI parity checking is enabled it will be checked and 


should be valid. Following an interrupt the BSR and CSD 


should contain the values shown below. 


Bit 7 Bit 0 


EDMA DRQ SPER INT PHSM BSY ATN ACK 
BSR 


‘Bit 7 Bit 0 


pofofeofofofo}itx 


RST BSY REQ MSG C/D 1/0 SEL DBP 
CSD 


6.0 Reset Conditions 


6.1 GENERAL 


There are three ways to reset the ASJ; uP chip RESET, 
SCSI bus reset applied externally, SCSI bus reset issued by 
the ASI. 


6.2 CHIP RESET 


When the RESET signal is asserted for the required dura- 
tion the ASI clears ALL internal registers and therefore re- 


BP Interface 


sets all logic. This action does not create an interrupt or 
generate a SCSI reset. 


6.3 EXTERNAL SCSI RESET 


When a SCSI RST is applied externally the ASI resets all 
registers and logic and issues an interrupt. The only register 
bits not affected are the Assert RST bit (bit 7) in the ICR and 
the TARGET Mode bit (bit 6) in MR2. 


6.4 SCSI RESET ISSUED 


When the »P sets the Assert RST bit in the ICR the RST 
signal goes active. Since the ASI monitors RST also the 
same reset actions as in 6.3 apply. The SCSI RST signal will 
remain active as long as bit 7 in the ICR is set—i.e. until 
programmed 0 or a chip RESET occurs. 


7.0 Application Guide 


This section is intended to show the interface between the 
pP, ASI and DMA controller (DMAC). Figure 7.7 shows a 
general interface when the ASI and DMAC are I/O-mapped 
devices. This configuration will implement a 2 to 2.5M 
Bytes/sec SCSI port using 2 cycle compressed timing from 
the 5 MHz DMAC. 


Using a faster DMAC and memory may allow the ASI to 
operate at a higher rate—but of course any system will be 
limited by the available DMA rate from the SCSI device cur- 
rently connected to. The interface shown has several fea- 
tures that are examined more closely in the following text. 
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FIGURE 7.1. ».P/ASI/DMA Interface 
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7.0 Application Guide (Continued) 


All the interface signal requirements are satisfied by a PAL 
device. The memory interface is not shown, only the rele- 
vant DMAC and pP lines are included. 


The ASI data and address lines connect directly to the wP/ 
DMAC busses. The DRQ output from the ASI goes direct to 
the DMAC. The EOP output from the DMAC goes to the ASI 
input, but can also be asserted via the PAL since the DMAC 
output is open-drain. 


The PAL is programmed so that the uP can access the ASI 
in three ways. The three access types are: Register R/W, 
DMA R/W, DMA with EOP. Examination of the PAL equa- 
tions below shows how the uP may perform any of the three 
basic access types simply by accessing the ASI at different 
I/O address slots. This enables the P to simulate a DMAC 
(pseudo-DMA). DMA mode may then be used for all infor- 
mation transfer phases. 


¢ 


in DMA mode the ASI generates all SCSI handshakes. At all 
other times the pP is responsible for REQ/ACK hand- 
shakes. Using pseudo-DMA may reduce uP overhead. 


When doing DMA transfers via BLOCK MODE and an error 
occurs, the ASI may not deassert the READY signal. For 
some DMA controllers this may lock the bus, so the PAL 
asserts READY and EOP to the DMA if an interrupt occurs 
while READY is false. This completes the current DMA cy- 
cle and prevents further DMA for the rest of the block thus 
allowing the bus to be handed back to the pP for servicing. 
The PAL generates RD and WR strobes while the pP is bus 
master, but the DMAC provides the strobes while it is bus 
master so the PAL outputs are TRI-STATE. 

The PAL details are shown in Figure 7.2 with the signal 
definitions and equations following. 


A7 
AG 
AS CSASI 
pP AA DACK As) 
iORG EOP 
RD 
ms NSC PAL sale 
CSDMA 
pwac AEN ia READY DMAC 
DDACK (OR 
MEMR 
EREADY MEMW 
ASI wT 
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FIGURE 7.2. interface PAL 
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7.0 Application Guide (continued) 


CSASI = IORQ*A7*A6*A5*A4*AEN; ASI reg R/W chip select 
ADACK = IORQ*A7*AG*A5*A4*RD; pP pseudo-DMA cycle 


TORQ*A7*AG6*A5*A4*WR 
| +IORQ*A7*A6*A5*A4*RD; pP pseudo-DMA with EOP 
| +I0RQ*A7*AG*A5*A4*WR 

+DDACK ; ; DMAC DMA cycle 


IF (AEN) AEOP = IORQ*A7*AG6*A5*A4*RD; pP pseudo-DMA with EOP 
+I0RQ*A7*AG*A5*A4*WR + DEOP* AREADY 
IF (DDACK*AREADY*INT)DEOP = DDACK*AREADY*INT 
;sDMA cycle with error 
CSDMA = IORQ*A7*AG*A5*A4 sDMAC register R/W 


DREADY = AREADY*INT sASI not READY and not INT 
+AREADY*DDACK ;ASI not READY and DMA cycle active 

IF(AEN)IOR = IORQ*RD suP I/0 Read cycle 

IF(AEN)IOW = IORQ*WR 3uP I/0 Write cycle 

IF(AEN)MEMR = IORQ*RD 34P memory Read cycle 

IF(AEN)MEMW = IORQ*WR 3mP memory Write cycle 


FIGURE 7.3. PAL Equations 


The uP and DMA signals are defined below 


A7-A4 Address bus 
10RQ Memory I/O cycle select 
RD * Read Strobe 

| WR Write Strobe 

| AEN High DMA address enable asserted by DMAC 

: DDACK DMAC DMA Acknowledge 

| CSDMA DMA Chip Select 

| DREADY Ready signal to DMAC—inserts wait-states when low 
IOR, IOW I/O data strobes to/from DMAC 
MEMR, MEMW Memory data strobe from DMAC 
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8.0 Absolute Maximum Ratings* 

if Military/Aerospace specified devices are required, 
please contact the National Semiconductor Sales 
Office/Distributors for availability and specifications. 


Supply Voltage (Vcc) —0.5V to + 7.0V 
DC Input Voltage (Vin) —0.5V to Voc + 0.5V 
DC Output Voltage (VouT) —0.5V to Voc + 0.5V 


Storage Temperature Range (Tstq) — 65°C to + 150°C 


Power Dissipation (Pp) 500 mW 
Lead Temperature (T,) (Soldering, 10 sec) 260°C 
Electro-Static Discharge Rating 2kV 


*Absolute maximum ratings are those values beyond which damage to the 
device may occur. 


9.0 DC Electrical Characteristics (Vcc = 5.0v + 10% unless otherwise specified) Ta = 0°C to +70°C 


symbol Conditions Limit | _Units 


Vin Minimum High Level 
Input Voltage 
VIL Maximum Low Level 
V 
Input Voltage 
Vout Minimum High Level llour = 20 pA Voc — 0.1 V 
VoHe2 Output Voltage llout| = 4.0 mA 2.4 V 
Vout Maximum Low Level SCSI Bus Pins: |Io,| = 48 mA V 
VoL2 Output Voltage Other Pins: |Io,| = 20 pA a V 
VoL3 llo.| = 8.0 mA eras V 
lIN Maximum Input Current Vin = Voc or GND Pkt pA 
loz Maximum TRI-STATE Output Vout = Vcc or GND 
+10 pA 
Leakage Current 
eve Supply Current Vin = Voc or GND 4 ak 
SCSI Inputs = 3V 
Capacitance 1, = 25°C, f = 1 MHz Voc fice) 
1 
| Symbol_| Parameter(Note 3) | Typ | Unite 
InputCapacitance | 5 | pF __ 
Output Capacitance 
R, =2.2k0 
Input O OUTPUT 


AC Test Conditions 


Input Pulse Level GND to 3.0V 
Input Rise and Fall Times | ons 
Input/Output Reference Levels 


TRI-STATE Reference Levels Active Low + 0.5V 
(Note 2) Active High — 0.5V 


Note 1: C, = 50 pF including jig and scope capacitance. 
Note 2: Si = Open for push-pull outputs. 

S1 = Voc for active low to TRI-STATE. 

S1 = GND for active high to TRI-STATE. 
Note 3: This parameter is not 100% tested. 
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10.0 AC Electrical Characteristics aii parameters are preliminary and subject to change without notice 


| Min 

bias | BSYFalsotoarbitrateStart_ | 1200, || z200 | 
bbc | ——BSYFalsotoBusCler | | | 00] 
st | RESETPusewidth | ts | tts 
stbo | SeLTnetoBusClear | | L800 


10.1 ARBITRATION 
= 
BSY ee a 
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10.2 uP RESET 
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10.0 AC Electrical Characteristics 


all parameters are preliminary and subject to change without notice (Continued) 


| Min | typ | Max 
ahr Address Hold from End of Read Enable (Note 1) ae aa ns 
ahw Address Hold from End of Write Enable (Note 2) | wo | | | ns 
as Address Setup to Read or Write Enable (Notes 1, 2) a a ae ns 
osh CS Hold from End of RD or WR PF oo | fons 
dhr Data Hold from End of Read Enable (Notes 1, 3) a a ae ns 
dhw »P Data Hold Time from End of WR ee 
dsw Data Setup to End of Write Enable a 7. ee ee ns 
rdv Data Valid from Read Enable (Note 1) a Ta 100 ns 
ww Write Enable Width (Note 2) | oo | | ts 


Note 1: Read enable (uP) is CS and RD active. 
Note 2: Write enable (uP) is CS and WR active. 


Note 3: This includes the RC delay inherent in the tests’ method. These signals typically turn off after 25 ns enabling other devices to drive these lines with no 
contention. 


10.3 uP WRITE 


aoe aa |-«—— ahw——+| 
|}~«————— ww ———+ | esh ——> 
|}+————. dsw——> | dhw ——+] 


ly (Avan (nit 


> 


=] 
Nad 
N 
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10.4 .P READ 


> 
2 
ib 


Se ee 


|~——— as-————_>| |~—--—- ahr ——> 


=] 
= 
N 
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10.0 AC Electrical Characteristics (continued) 
10.5 DMA WRITE (NON-BLOCK MODE) TARGET SEND 


|-— dtaf —>| |<— dfdt —>| 

|~——— wwn ——>}«— dk hw ——> 
Dp nn [ae 

|\~«——— dswd ——>|<— dhwr —>| 


[+ 20 —> 


eS. ee 
ACK \ / 


Symbol Parameter 

| omin | typ | Max 
ait | ACKFalsetoREQTue(DACKorWRFalse) || | tt 
att | ACKTuetoDRQTwue Tage) ||| 
at | ACKTrustoREGFalse (Target) fC | 
aitt___| _DACKFalsetoDRQTue | 80 
dit___| DACKFalsetoREQTrue (ACK False) | 
dhwr__| _DMADetaHoldTimefromEndofWR | 80 
aitw | DACKHoldfromEndofWR | 
dst_| _SCS1Data Setup toREQ True (TargetSend) (Note1) | 40_| 
dowd | _DetaSetuptoEndofDMAWrteEnable |_| 

a 

<a 

ms 


dtdf DACK True to DRQ False 
eop Width of EOP Pulse (Note 2) 


wwn DMA Non-Block Mode Write Enable Width (Note 3) 


Note 1: EOP, DACK, RD/WR must all be true for recognition of EOP. 
Note 2: Write enable (DMA) is DACK and WR active. 
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Units 


ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 


ns 
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10.0 AC Electrical Characteristics (Continued) 
10.6 DMA WRITE (NON-BLOCK MODE) INITIATOR SEND 


DRQ / \ / 


je tf ———»| |~«—— dfdt ——> 
—— wwn——>}___—— dkhw >| 
i (en aa 
|«——— dswd ——>}+— dhwr —>| 


DO..7 x X 


| — e0p — 


|~<—>| rfdt 


REQ \ / 
ACK \ / 


~— dhi—> 


DB0..7,P Byte n X X Byte n+1 


Symbol Parameter 
ee ee a 
dfaf___|__DACKFalsetoACKFalse(Non-Block iniiatorSend) | || | 120 
didt____ | _DACKFalsetoDRQTue =| | 
di |_SCSIDataHoldtrom Write Enable—inator | 18 | | 
dhwr___ | _OMADataHoldTimefromendofwR | 90 | S| 
akhw | DACKHoldfromendofWR | TT 
dswd___| _DataSetuptoEndofDMAWrteEnable | 50 | | 
ati | DACKTretoDRQFalse =| | | t0 
cop | WidthofEOPPulse(Notet) =| || 
fat | REQFalsetooRaTue =| | t00 
at | REQTruetoACK True (IniiatorSend) | | | 100 
wwn | __DMANon-BlockMode Write Enable Width (Note2)_ | 60 | | 


Note 1: EOP, DACK, RD/WR must all be true for recognition of EOP. 
Note 2: Write enable (DMA) is DACK and WR active. 
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Units 


ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 


ns 


10.0 AC Electrical Characteristics (Continued) 
10.7 DMA READ (NON-BLOCK MODE) TARGET RECEIVE 


DRQ / \ / 


|+— dtdf —>| |~—— dfdt ——> 


DACK \ / 


a 


kddv>| /~+— dhr —>| 


DT TD 


[+ 209 —+} 


k— atat—>| |-— afrt —>| 
>| [= att [+— afrt—>} 


ACK \ / 


|~+dsra>|<—— dhra ——>| 


0B0..7,P Xfyten X Seer 


DP5380 
Typ 


Symbol Parameter 


afrt ACK False to REQ True (DACK or WR False) 

atdt ACK True to DRQ True (Target) 

atrf ACK True to REQ False (Target) 

ddv DMA Data Valid from Read Enable (Note 1) 

DACK False to DRQ True 

dfrt DACK False to REQ True (ACK False) 

dhr Data Hold from End of Read Enable (Notes 1, 2) 

dhra SCSI Data Hold from REQ or ACK True (Receive) 

dkhr DACK Hold from End of RD 

dsra SCSI Data Setup Time to REQ or ACK True (Receive) 
- dtdf DACK True to DRQ False 


eop Width of EOP Pulse (Note 4) 
Note 1: Read enable (DMA) is DACK and RD active. 


2. 

a. 

- 
(2) 


— 
nN 
© 


awh, 
ach 
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Units 


ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 


ns 


Note 2: This includes the RC delay inherent in the tests’ method. These signals typically turn off after 25 ns enabling other devices to drive these lines with no 


contention. 
Note 3: EOP, DACK, RD/WR must all be true for recognition of EOP. 


O8eSdd 


© 

Cc 

iB 10.0 AC Electrical Characteristics (Continued) 
© 10.8 DMA READ (NON-BLOCK MODE) INITIATOR RECEIVE 


DRQ / \ / 


~— dtdf —>| |~—— dfdt ——>| 
|< dkhr ———+| 
7 Oe 
Kd] f+ tr} ——} 


ST TD 


a aid 
i en aa 
— redt —>| pS tel 
~— rtat —>| ~+— dfaf —>| 
a nny arr 


+ dsra->|}«—— dhra——>| 


0B0..7,P X___fyten X en ae 
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Symbol Parameter Units 
pe 
ddv__| _OMADataValidtromReadEnable Notes) | | | | 
dtat__| _DACKFFalsetoACK False (REQFalse, Non-block in) | |_| t20 | 
atat___| DAcKFalsetopRatwe | go] | 
dhr_ | _DataHoldtromEnd of Read Enable Notes 1,2) | to | | eos 
dnra__ | SCSiDataHoldfromREQorACK True (Receve) |__| | | 
aitr_ | DACKHoldfromendofRD | Pt 
dsra__| _SOSiDataSetupTimetoREGorACK Tue Receive) | 20 | | | 
aat_ | packtustoprarase | | 00 
eop___|_Widthofeorruse(Notes) | | | ts 
raf___| REQFalsetoACKFatso(DACK False) | | | t00 | 
nat____| REQTuetoACK True niatorReceve) | | | t00 | 
ndt__|_ReQTwetopRaTwe | tt 


Note 1: Read enable (DMA) is DACK and RD active. 


Note 2: This ‘includes the RC delay inherent in the tests’ method. These signals typically turn off after 25 ns enabling other devices to drive these lines with no 
contention. 


Note 3: EOP, DACK, RD/WR must all be true for recognition of EOP. 
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10.0 AC Electrical Characteristics (Continued) 
10.9 DMA WRITE (BLOCK MODE) TARGET SEND 


|+~—_— dswd——>}<—— dhwr: —>| 


I+ cop —e4 
rr, 
— |] wit + 
|—————- afrt ———_—> 
ar 
|}~————- atrt ———__>|+____—— rtwf —_____> + wfrf ——>| 


+ dhat ———__> a.) ened 


DBO..7,P Byte n x X Byte n#1 
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Symbol Parameter Units 
a... ss 
at __|_ACKFalsetoREQTrue(DACKorWRFalse) ||| 120 ns 
af |_ACKTruetoREQFalse(Target) =| | || 
atrt___—|__ACKTruetoREADY True (BlockMode TargetSend) | | | 110 | 
dhat___ | __SCSiDataHoldfromackTue | 40 | | 
dhwr___ | _DMADataHoldTimefromendofwR | 0 | S| | 
dst | _—SCSiDataSeuptoREQTue = “|| | | | 
dswd | _DataSetuptoEndofDMAWnteEnable | 50 | S| |g 
dtdt___—|_DACKTuetoDRaFalse = | | | 00S | 
cop | _WidthofEOPPulse(Notet) =| | | | 
wt | _READYtuetowRFalse = | | | ts 
wit __ | _WAFalsetoREADYFalse =| | | 100s 
wit | _WRFalsetoREQTrue(acKFalse) = | || t20 | 
wwb | DMAWriteEnablewidth(notez) | | | ts 


Note 1: EOP, DACK, RD, WR must all be true for recognition of EOP. 
Note 2: Write enable (DMA) is DACK and WR active. 
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10.0 AC Electrical Characteristics (Continued) 
10.10 DMA WRITE (BLOCK MODE) INITIATOR SEND 


be dtdf >| 


DACK \ 


+—— wwh-——>| 


|~— dswd —>}+—— dhwr- ——> 


|-— sp —+ 


EOP 


LF Ka 


|«——+| rtat |<—>| wiaf 


rtwf —————>|«— wfrf —>] 


DBO..7,P Byte n x X Byte n+1 
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Symbol Parameter oer Units 
: | Min | typ 


| Max 
ahi | SCSIDataHoldtromwriteEnable—inttator | ts | | 
dhwr | DMADataHoldTimefromendorwa | 0 | | | 
dswd | __DataSetuptoendofDMAWrteEnable | 0 | | 
dat | DaCKTruetoDRFase | | | t00 | 
cop | Width of EOPPulse (note | oT Tt 
ryt | REQFalsotoneADYTue | | ts 
rat_|_ReQTwetoackTue | TT tc 
rw! | READYTruetowRFalse | | Tt 
wit | WRFalsetoAckFalso(Rearase) | | | tz |g 
wit | _WRFalsetoREADYFase | | | tt 
ww |_DMAWriteEnablewiatn (note t) | so | | Tt 


Note 1: Write enable (DMA) is DACK and WR active. 
Note 2: EOP, DACK, RD/WR must all be true for recognition of EOP. 
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10.0 AC Electrical Characteristics (continued 
10.11 DMA READ (BLOCK MODE) TARGET RECEIVE 


DRQ / \ 


|x — dtdf —>} 


DACK 


eX |+—— dhr —>| 


rae eel 
ns OEE ces 
+} rik ——+ 
+ atrf >| + afrt ———__> 
[+ atyt->}<——— rydv- >| /~——_—— rfyf ——___> 


READY / \ 


|— dsra —>/<—— dhra => 
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Symbol Parameter tt Units 


afrt ACK False to REQ True (DACK or WR False) 

atrf ACK True to REQ False 

atyt ACK True to READY True 

ddv DMA Data Valid from Read Enable (Note 1) | 

dhr Data Hold from End of Read Enable (Notes 1, 2) 
SCSI Data Hold from REQ or ACK True 

dsra SCSI Data Setup Time to REQ or ACK True 

dtdf DACK True to DRQ False 

eop Width of EOP Pulse (Note 3) 

rfrt RD False to REQ True (ACK False) 

rfyf RD False to READY False 


rydv READY True to Data Valid 
Note 1: Read enable (DMA) is DACK and RD active. 


Note 2: This includes the RC delay inherent in the tests’ method. These signals typically turn off after 25 ns enabling other devices to drive these lines with no 
contention. 


Note 3: EOP, DACK, RD/WR must all be active for recognition of EOP. 
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10.0 AC Electrical Characteristics (Continued) 
10.12 DMA READ (BLOCK MODE) INITIATOR RECEIVE 


|}+—— dtdf —> 


RD 
Bata — dhr ——>| 
) iS Sea Te Gees 
i: aad 
|«_____—— rfaf ———_———>| 
>| ~~—rtat +¥—_—— rfaf ——>| 
ACK 
j= rtyt->}<—_——— rydv- ———> }~————— rfyf ————> 
READY 
— dsra—>}-— dhra—> 
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Symbol Parameter Units 
en er ce 

div | __DMADataValidtromReadEnable(notet) |_| || 
dhe | _DataHoldfromEndofReadEnable(Notes 1.2) | 10 | | eo | 
dna | SCSiDataHoldfromREQoracktue | go] || 
dera___—|__SCSIDataSetupTimetoREQorackTue | 20, | | | 
diat_——|—<DACKTruetoDRQFase =| | | t0 | 
cop | __WidthofEOPPulse (Notes) = | S| | 
rdat___—| ~—ADFalsetoACKFalse(REQFalse) = | | 18 ns 
rat (| __REQFalsotoACKFalse(DACKFalse) || | 100 ns 
iyi | _RDFalsetoREADYTueFase = | S| | ttn 
nat2 | —REQTuetoackTue = | | 100 ns 
ryt | —REQTwetoREADYTue =| | | 
nav _ | READY Tuetodatavaid = | | | 


Note 1: Read enable (DMA) is DACK and RD active. 


Note 2: This includes the RC delay inherent in the tests’ method. These signals typically turn off after 25 ns enabling other devices to drive these lines with no 
contention. 


Note 3: EOP, DACK, RD/WR must all be active for recognition of EOP. 
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Appendix A1 


Arbitration and (Re)Selection 


ODR = device ID 
Set MR2: ARB 
(bit 0) 


Check ICR AIP 
(bit 6) 


Reset 


WAIT BUS FREE + 
ARBITRATION Delays 
(800 # 2200nS) 


Check ICR LA 
(bit 5) 


Reset 


Read CSD and resolve 
ID priorities 


This device 
ID is highest? 


Yes 


Set ICR : ASS=SEL 
(bit 2) 


Wait BUSCLEAR + 
BUS SETTLE delays 
(800 + 400nS) 


No = Selection 


Reselection 


Set MR2: TARGET 
MODE (Bit 6) 
Set TCR ASS 1/0 
(bit 0) 


TL/F/9756~-24 
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SELECTION 


s 
Set ICR: DBUS, 
ATN, SEL (Bits 0, 1 , 2) 


ODR = device 
ID OR'd 


with controller ID 


RESELECTION 


"Set ICR: DBUS, 
SEL (Bits 0, 1) 


Ensure SER=0 
Reset MR2: ARB 
(Bit 0) 


BSY active 


within SELECTION No 
TIMEOUT DELAY 
(250mS)_ 
Yes : Error Routine 
SELECTION RESELECTION 


Set ICR: BSY (Bit 3) 


Reset ICR: DBUS, SEL 
(Bits 0, 2) 


Rest ICR: DBUS, SEL 
(Bits 0, 2) 


Information 
Transfer Phases 


TL/F/9756-25 
*Only set ATN if Select with ATN is desired. 
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Appendix A1 (Continued) 


Command Transfer (Initiator) 


Set MR2:BSY (bit 2) | 
Set TCR:C/D (bit 1) 


Phasematch 


: 


ODR = Command byte 
Set ICR: Asset ACK 
(bit 4) 


CSB: REQ 
(bit. 5) 


0 


Reset ICR: ASS_ACK 
(bit 4) 


More bytes? 


NO 
NEXT PHASE 
TL/F/9756-26 
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Command Transfer (Target) 


Message_out 
Phase 


ATN active? 
BSR Bit 1 


Set TCR:C/D(bit 1) 


Wait Bus Settle Delay 
Set TCR : ASS_REQ (bit 3) 
0 BSR : ACK? 
(bit 0) 
1 


Command * CSD 
(Parity checked if enabled) 


Verify Operation Code 
setup CDB length 


Reset TCR: ASS_REQ 


BSR: ACK? 
(bit 0) 


0 
Transfer remaining 
CDB bytes 
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Appendix A2 
| ' Register Chart 
READ WRITE 

Bit 7 Current SCSI Data (CSD) Bit 0 Bit 7 Output Data Register (ODR) Bit 0 
oer [nt | ms [ us [ us [oe [|v] [or [ow | os | vs | vs | ve [vr reo 
Bit 7 Initiator Command Register (ICR) Bit 0 Bit 7 Initiator Command Register (ICR) Bit 0 
Bit 7 Mode Register 2 (MR2) Bit 0 Bit 7 Mode Register 2 (MR2) Bit 0 
eux [ranl ren er] cor] 5% [oun] ano] [sux [oo] ener] or 6” [oun] ono 
Bit 7 Target Command Register (TCR) Bit 0 Bit 7 Target Command Register (TCR) Bit 0 
po fo | o | o |reajms| om) mo] |x |x| x | x [rea/mse] om] vo 
Bit 7 Current SCSI Bus Status (CSB) Bit 0 Bit 7 Select Enable Register (SER) Bit 0 


rer] as [reac o | vo [sexo] [ver] wx | vs | | oes | re | os [on 
Bit 7 Bus and Status Register (BSR) Bit 0 Bit 7 Start DMA Send (SDS) Bit 0 
na] oe sen] wr [oven sev] xox] [x Tx] [x |x|] x] 
Bit 7 Input Data Register (IDR) Bit 0 Bit 7 Start DMA Target Receive (SDT) Bit 0 
oe7 | pas | ves | oes | oes | owe] vei |oe] | x | «| x] x |x] x] x] 
Bit 7 Reset Parity/Interrupt (RP!)—Mode N Bit 0 Bit7 Start DMA Initiator Receive (SDI)}—Mode N Bit 0 
X = Unknown X = Don’t Care 
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Realize the Speed of 


Asynchronous SCSI 


National Semiconductor’s new SCSI Interface devices 
raise the standard of low cost SCSI. 


National Semiconductor has two new low cost, high per- 
formance Small Computer Systems Interface (SCSI) devic- 
es; the DP5380 and DP8490. The DP5380 Asynchronous 
SCSI Interface (ASI) i is pin and program compatible with the 
NMOS NCR5380 type device, but since it is manufactured in 
CMOS it offers speed and power advantages. The DP8490 
Enhanced Asynchronous SCSI Interface (EASI) is pin com- 
patible with the ASI, and program compatible until its en- 
hanced mode is set. This mode offers features and architec- 
tural improvements which can greatly increase a system’s 
throughput. However a major factor in favor of both devices 
is the improvement in their achievable data transfer rate. 


Users who have replaced their NMOS 5380 type devices for 
National devices, in an existing application, have found im- 
provements of between 10 and 15 percent in data transfer 
speeds. That is with no other changes to their application. 
For new designs, or performance upgrades, the gains possi- 
ble can be much more dramatic. 


In many applications the limiting factor in a data transfer is 
the DMA controller. This presented a problem to users i.e., 
“How fast can the National devices transfer data?” To de- 
termine this National designed an asynchronous DMA con- 
troller, using a programmable gate array, which can go as 
quickly as the SCSI device will allow it. In these tests the 
National devices were up to 140% faster than the 
NCR5380 equivalent. 


SYSTEM OVERVIEW 


A general SCSI application is shown in Figure 7. This shows 
the hardware required to interface a SCSI bus to a peripher- 


Data Bus 
Address Bus 


National Semiconductor 
Application Note 575 
Andrew M. Davidson 


al controller, without the devices to control the peripheral 
itself. The Central Processing Unit (CPU), the only “‘intelli- 
gent” device, controls all operations. It communicates with 
the SCSI bus through the EAS! or ASI, which both support 
selection, reselection, arbitration and all other bus phases 
detailed in the ANS X3.131-1986 SCSI standard defined by 
the ANSI X3T9.2 committee. Since these devices can act as 
both target and initiator this could be the core of a peripher- 
al controller or a host adaptor. 


For optimum performance a DMA controller is used to trans- 
fer data between the SCSI device and memory. This memo- 
ry is used as a cache for the final destination, which could 
be main system memory, a hard disk, floppy disk, printer, 
etc. By adding the appropriate interface the core shown in 
Figure 7 can be adapted for the particular application. 


TEST SYSTEM 


To fully test the achievable DMA rate National built two 
boards of the form shown in Figure 7. The first board config- 
ures itself as an initiator, the second acts as a target. The 
initiator arbitrates for the SCSI bus, until successful, then 
selects the target and sends a Write command. This causes 
a DMA transfer from the initiator to the target. 


The initiator arbitrates for the bus again, selects the target 
and sends a Read command. The data sent to the target is | 
returned to the initiator, under DMA control, and checked. 
This process is constantly repeated, with the transmitted 
data varying between “01,FF,00,01 etc.” and ‘‘FF,01,00,FF 
etc.” This checks every data bit and varies the parity bit. 
The two boards continually transmit blocks of data, alternat- 
ing between Initiator Send/Target Receive and Initiator Re- 
ceive/Target Send modes. 


fo Ik - Ik a IL l : 
Bus 
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FIGURE 1. Core of a SCSI Controller 
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TEST CIRCUIT 


The two boards have identical circuitry, shown in Figure 2. 
The CPU is an NSC800™ 8-bit CMOS microprocessor, 
which requires an octal latch to demultiplex the address and 
data bus. The boards configuration, initiator or target, de- 
pends on the system software stored in the EPROM. Fast 
static RAM is required for the cache, CMOS RAM with an 
access time of 45 ns was selected. A PAL® is used to de- 
code the chip selects. The SCSI controller can be either a 
5380 or a DP8490. 


The DMA controller was implemented in a Xilinx Program- 
mable Gate Array. These devices offer a quick, easily adapt- 
able method of prototyping. The design is entered as a 
schematic, then converted to the gate array format by a 
software package. Routing is largely automatic, but complex 
designs require a certain amount of interaction. In a speed 
critical design, such as the DMA controller, manual control 
of routing delays is vital. 

The Xilinx device can automatically load its configuration 
from an EPROM on power-up. This could be the same 
EPROM that contains the boards software, but for simplicity 
during prototyping a separate device was used. 


NSC800 
processor 


DMA DESIGN 


The DMA controller required was highly application specific 
and could therefore be relatively simple. It basically consists 
of a counter, a register and control logic (Figure 3). The 
counter is loaded with the start address of the DMA block 
and the register with the end address. On a subsequent 
DMA request the controller has to take control of the micro- 
processor bus and transfer data until the address in the 
counter equals the address in the end register. 


The DMA is enabled by setting a bit in the control register. 
The other control bit determines whether the transfer is a 
memory read or a memory write. 


Once enabled, a subsequent DMA request (DRQ) will cause 
the device to issue a bus request (BRQ). When it receives a 
bus acknowledge (BACK) from the processor it asserts the 
counter output onto the address bus and issues a DMA ac- 
knowledge (DACK). The DMA controller also takes control 
of the |/O and memory read and write strobes. This device 
only operates in block mode, so DACK is asserted through- 
out the transfer. The SCSI device deasserts DRQ when 
DACK goes active. This is used to start the first transfer. 
Subsequent transfers are triggered by the throttle control, 
READY, going high. 


Controller scsi 


5380 


or 
8490 


16 Bit Address Bus 


8 Bit Data Bus 


Control Signals 


Xilinx 
Config. 
y «EPROM | 


~ “independent _ 
control lines 
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FIGURE 2. Circuit of SCSI Test Board 


4-73 


SZS-NV 


AN-575 


For a memory read, RD is held active throughout the trans- 
fer and [OW is strobed. For a memory write, both IOR and 
WR are strobed. The basis of the control logic is shown in 
Figure 4. 


Figure 5 shows the timings of the circuit in Figure 4. The 1/O 
or memory strobe pulses low for the time difference be- 
tween READY going high and the STROBEIN input causing 
CLOCK to go high. Thus the external delay line controls the 
strobe signals pulse widths. The back edge of CLOCK is 
used to increment the address counter. 


Load Low Byte 
> aaa 
Load High Byte 


End Address Register 


Comparator Sea 
Li % Load Low Byte 
i See: 


Current Address Counter Ed Load High Byte 


Equal Addresses 


Counter Increment 


16 Bit Address Bus 
8 Bit Data Bus 


AO Al A2 


2 Control Bits 


RD ioW WR 


The controller continues as in Figure 5, until the EOP (End 
of Process) signal is asserted. This is either asserted exter- 
nally, to prematurely end a transfer, or by the DMA control- 
ler itself, once the current address counter equals the end 
address register. 


The speed that the DMA controller transfers data is deter- 
mined by the READY line. The SCSI controller deasserts 
READY after an IOW or IOR, then asserts it when it is ready 
to transfer the next byte. This high transition triggers the 
next transfer of the DMA controller. Varying delay line time 
varies the IOR, IOW and WR pulse widths, so different 
speeds of devices can be accommodated by this controller. 


CS (chip select) 


DMA request 
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Control Logic Bus acknowledge 


READY (throttle 
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FIGURE 3. Block Diagram of DMA Controller 
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FIGURE 4. DMA Control Logic 
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FIGURE 5. DMA Controller Timings 
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BENCHMARKING 
The system used for the benchmarking is shown in Figure 6. 


The two boards were connected by three different lengths 
of cable; 50 cm, 3m and 6m (the maximum length of single 
ended cable allowed). 50-way STD IDC ribbon cable was 
used, wired as per SCSI specification with every second line 
grounded. All SCSI signal lines were terminated on both 
boards, with a 3300 resistor to ground and a 2200 resistor 
to Voc. | 


A Hewlett Packard 16500A Logic Analysis system was used 
to monitor the control signals and measure the burst DMA 
rate. The 10 ns sampling rate gave sufficient accuracy to 
measure handshaking speeds which were all below 
5 Mbytes/s. 


The first byte of a transfer is delayed, as the initiator takes 
time to follow the phase set by the target. After this the 
DMA controller reaches its peak transfer rate, which is 
maintained until the end of the transfer. The frequency of 
the SCSI bus handshaking signal, REQ, was measured, to 
give the data transfer rate. . 


BENCHMARKED DEVICES 


Initially it was planned to benchmark three manufacturers 
devices, that is National Semiconductor, NCR and Logic 
Devices. 


However it was found that the Logic Devices part caused 
problems in the test board and would not function in con- 
junction with any other manufacturers device. The DMA 
controller uses DRQ to generate the first read and write 
strobes (see DMA Design section), but expects the signal to 
stay inactive for the rest of the transfer. The Logic Devices 
5380 produces a spurious DRQ during a block mode trans- 
fer. This corrupts the read and write strobes produced by 
the DMA controller. The Logic Devices 5380 would not in- 
terface to other manufacturers devices because of its parity 
checking method. National and NCR only check the bus 
parity as they load their input data register. Logic Devices 
check parity when ACK is active, for Target Receive or 
when REQ is active for Initiator Receive. However, the Na- 
tional and NCR devices write the next byte of data before 
the REQ/ACK handshake for the previous byte is complete. 
As parity is decoded through logic the data will be on the 
bus before the parity bit is valid. Logic Devices detect this as 
a parity error, which causes the transfer to be terminated. 


The National and NCR devices were fully interchangeable. 
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FIGURE 6. Benchmarking System 
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BENCHMARK RESULTS 


The transfer rate during a data phase was measured for a 
sample of National and NCR devices, over three lengths of 
cable. Measurements were made for Initiator Send/Target 
Receive mode and for Initiator Receive/Target Send mode. 
When a NCR device was used the delay line time was in- 
creased, to allow for its slower reading and writing times. 
Figures 7a, b and c show the results. 


These tables show the dramatic speed advantages of the 
National device over NCR. The National device maintains a 
significant advantage over all three lengths of cable. It may 
appear that the NCR device maintains its speed better over 
longer lengths of cable, but only because the added propa- 
gation delays of the cable are a smaller percentage of the 
transfer time. 


a. 10cm Cable 


' Speed in Mbytes/second 


initiator 
Target 
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The Initiator Receive/Target Send mode is inherently faster, 
which makes the specification of one DMA rate for the de- 
vice a highly debatable subject, even if the length of cable 
for the measurement is agreed. However, customers using 
the SCSI device for a disk application will appreciate the 
fact that this mode is faster, since approximately 80% of 
disk accesses are reads, while running most software. 


Even if only one National device is used there is a signifi- 
cant improvement in performance, but to fully realize the 
potential of the SCSI interface two National devices are re- 
quired. Figure 8 shows just how much of an improvement 
this is. 


b. 3m Cable 


Initiator. Speed in Mbytes/second 
Target 


— . = 3 


Note: The upper value shows Initiator Send/Target Receive while the lower 
shows Initiator Receive/Target Send. 


FIGURE 7. Measured DMA Transfer Rate 
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FIGURE 8 


CONCLUSIONS 


The new asynchronous SCSI interface devices from Nation- 
al offer an instant improvement to old designs. By changing 
over to National devices the user can upgrade an existing 
SCSI interface by upwards of 10%, with no further effort. 
For greater performance improvements a fast DMA control- 
ler is required, at which point the asynchronous SCSI ap- 
proaches synchronous SCSI speeds. 

For new designs the DP8490 EASI is the ideal choice. In 
addition to the fast DMA transfer rate, this device offers 
architectural improvements which can greatly boost a sys- 
tems throughput. In a 5380 the arbitration time is dead to 
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the system, as the device must be polled to determine when 
this phase has started. By interrupt driving arbitration the 
DP8490 EASI frees many milliseconds, or even seconds, to 
be used at the system designers discretion. This time may 
be utilized for disk cacheing, overlapped seeks, printing etc. 
depending on the particular application. The entire interrupt 
structure has been revamped, making software for this de- 
vice quicker to develop and quicker to run. To further ease 
software overheads the troublesome bugs of the 5380 have 
been fixed. 


By improving the speed of data transfers, lowering the pow- 
er consumption and offering new additions to a familiar 
SCSI interface device, National have rejuvenated asynchro- 
nous SCSI. 


DP8490: E.A.S.I. Does It! 


National’s Enhanced Asynchronous SCSI Interface (EASI) 
Offers features that can yield increases in system perform- 
ance over designs incorporating a 5380 type device. 


When looking for a low cost Small Computer Systems Inter- 
face (SCSI) controller many users adopt the 5380 Asyn- 
chronous SCSI Interface (ASI) despite its many document- 
ed flaws and undocumented difficulties in operation, familiar 
to any past user. This device tended to be selected due to 
the lack of an alternative, but the DP8490 EASI from Nation- 
al Semiconductor will change this. The EASI is pin compati- 
ble with the ASI, and software compatible until an enhanced 
mode bit is set. This enhanced mode offers features which 
can increase the performance of a system currently using a 
5380 type device. This is achieved through improvements to 
speed and architecture, while eliminating the 5380’s inher- 
ent bugs. 


SYSTEM OVERVIEW 


The DP8490 and DP5380 support selection, reselection ar- 
bitration and ail other bus phases as detailed in the ANS 
X3.131-1986 SCSI standard defined by the ANSI X3T9.2 
committee. As the devices can act as both TARGET and 
INITIATOR they are suitable for any SCSI bus application. A 
typical application will look like Figure 7. 


The C.P.U. controls all operations by reading and writing 
registers in the I/O devices; to achieve a high performance 
a member of the HPC16000 microcontroller family can be 
used. For optinum performance a DMA controller handles 
data transfers between the EASI and memory. The memory 
is used as a data cache for the final destination, which may 
be a hard disk, RAM disk, printer etc. Figure 7 shows the 
basic system but not the hardware required to interface to 
such a peripheral. The EASI has high-current open-drain 
drivers which interface directly to the SCSI bus. 


SPEED AND POWER IMPROVEMENTS 


National’s DP8490, and DP5380, are implemented in low 
voltage silicon gate microCMOS, which gives power and 
speed improvements over existing NMOS 5380 parts. The 
National devices have a maximum supply current of 4 mA, 
compared to the NCR5380 145 mA, and DMA rates of over 
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3 Mbytes/second, compared to 1.5 Mbytes/second. Nation- 
al’s EASI device has reduced timing parameters; read ac- 
cess times are reduced from 130 ns to 50 ns, write data 
hold times, from 30 ns to 10 ns and all other parameters 
correspondingly improved. | 


ENHANCED INTERRUPTS 


The DP8490 enhanced mode interrupt structure is consider- 
ably different to that of the 5380. The source of interrupt is 
available by reading one register, the Interrupt Status Regis- 
ter (ISR). In order to find the source of interrupt in the 5380 
two registers must be read. In addition all interrupts are 
flagged in enhanced mode. With the 5380 a selection inter- 
rupt has to be determined by the absence of other flags 
while the select line is active. Since selection is the means 
of establishing contact with other devices on the SCSI bus it 
is a common occurrence. The DP8490 supplies an interrupt 
flag for this and all other interrupts. This enhanced interrupt 
structure should simplify system software, thus increasing 
the speed of interrupt servicing. Simplified code is easier to 
understand, and therefore easier to adapt or repair. 


All interrupts are maskable, using the Interrupt Mask Regis- 
ter (IMR), but interrupts cannot be lost since resetting the 
interrupts only resets those bits that were active on the last 
read of the ISR. This achieves a greater error tolerance. 


INTERRUPT DRIVEN ARBITRATION 


An enhancement which will have a great effect on many 
system’s performance is the addition of an arbitration inter- 
rupt. In the 5380, arbitration is polled. On a busy SCSI bus, 
arbitration will take typically many milliseconds, and poten- 
tially many seconds. Therefore, time which could have been 
spent doing overlapped seeks, or filling a data buffer is in- 
stead used reading a 5380 register waiting for a flag to go 
active. The enhanced mode of the DP8490 offers interrupt 
driven arbitration, allowing the user to utilize this time in data 
cacheing, data manipulation, etc., thus increasing the sys- 
tem throughput. This increase in system performance can 
become particularly effective in low priority devices which 
will typically have to arbitrate for the bus the longest. 
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FIGURE 1 
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INCREASED TESTABILITY 


; The enhanced mode is set using a register bit which, in the 
.. 5380 initiates the ‘Test Mode’. In Test Mode all output driv- 
ets on the:device are disabled, so although the device can 


Still be written, no data can be read. This makes it unsuitable 
for any application. In addition, DMA and interrupt requests 
are tri-stated, which may cause system problems. — 


‘In contrast, the enhanced mode of the DP8490 offers a 


loopback facility, where the SCSI drivers are disabled, and 
the SCSI !/O’s loop back inside the EASI. This loopback 
test mode allows all device signals to be fully tested, includ- 
ing a DMA transfer. Using this, a system can perform a full 
self diagnostic test, without affecting the SCSI bus. Good 
diagnostic testing simplifies system error detection and 
checking. 


TRUE END OF DMA DETECTION 

Another interrupt improvement in the enhanced mode is 
seen during DMA operation. The 5380 will generate an end 
of DMA interrupt when it sees a concurrent EOP, DACK and 
lIOR or IOW, even though the SCSI bus transfer may not be 
complete. To overcome this the user must examine REQ 
and ACK, to determine a true end of transfer. Consider Fig- 
ure 2: 


REQ 
ACK 


DACK 


EOP 
IOR or 
low 
A B 
TL/F/10081-2 
FIGURE 2 
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If an initiator is slow in removing the ACK, the processor 
could sample REQ and ACK after the EOP interrupt, at point 
A. At this point REQ and ACK are both inactive, although 
there is still one byte to transfer. The user must see REQ 
and ACK inactive on three successive transfers to be confi- 
dent the transfer is complete (point B). Thus a great deal of 
time is wasted ensuring the last byte of every DMA transfer 
is successful. The EASI eliminates this inefficiency by de- 
tecting, and interrupting on, true end of DMA, when ACK 
goes inactive. 


TIMING ENHANCEMENTS 


Some of the major bugs in the 5380 are experienced in 
DMA mode. In initiator receive mode, if a REQ is received, 
after a valid EOP, an ACK will be generated although no 
valid data exists. This could be a particular problem for us- 
ers who have to split a block transfer into two, perhaps to 
prevent crossing a page boundary. Part of the second block 
of data could be lost by the generation of these spurious 
ACK’s. Another problem experienced by an initiator in DMA 
mode is ACK being left asserted after receipt of a valid EOP. 
After receiving the end of DMA interrupt the processor must 
‘manually’ deassert ACK by writing to the relevant register. 


These problems make the DMA mode in a 5380 extremely 
difficult to use. Extra software is required to ensure correct 
operation, making boards incorporating a 5380 run slower. 
None of these problems exist in the enhanced mode of 
the DP8490. 


BUS TERMINATION 


The most common SCSI bus is a 50 way ribbon cable, of up 
to six meters long, with SCSI devices daisy chained along it. 
The devices at either end of the bus should terminate all 
SCSI lines with a 3300 resistor to ground and a 220 to 
power. To ensure the bus can operate correctly, even if the 
device at one end is not powered up, the power to these 
terminators can be made available on the SCSI bus. This 
allows the terminators to always receive power. The bus 
configuration is shown in Figure 3. Terminator power is fed 
through a Schottky diode to prevent a backflow of power 
into either of the devices. 
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FIGURE 3 
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Some manufacturers’ CMOS devices will not work in this 
configuration, since when not receiving power they pull the 
SCSI line low. Therefore all devices on the bus must be 
powered up. Both National’s DP5380 and DP8490 have a 
special input protection which makes this configuration ac- 
ceptable. 


EXTENDED FEATURES 


The DP5380 and DP8490 are available in a standard 40 pin 
DIP, or in a 44 pin PLCC, which is pin compatible with exist- 
ing 5380 PLCCs. The DP8490 PLCC has a microprocessor 
parity pin. In the enhanced mode, microprocessor bus parity 
checking can be enabled, with parity polarity optional. Since 
parity checking is optional, the PLCC DP8490 can still be 
used in a system where the microprocessor does not sup- 
port parity. However, use of this feature will help the confir- 
mation of data validity throughout the system. 


Enhanced mode (for both types of packaging) offers other 
features, including programmable SCSI parity polarity. Al- 
though the specified SCSI polarity is ODD, by enabling 
EVEN parity bus diagnostics can be carried out. In this way 
the error detection and error handling capabilities of other 
devices on the bus can be determined. 
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The enhanced mode also has a general phase mismatch 
interrupt. The 5380 only checks phase mismatch during 
DMA. This means that an initiator following the phase set by 
a target must poll the device to determine when it changes. 
Only a change during DMA produces an interrupt. In the 
enhanced mode, an option available gives an interrupt on 
any phase mismatch. This allows for quicker detection of a 
change of phase, thus decreasing the dead time on the 
SCSI bus. 


The wide range of new features available in the DP8490 
makes this part a first choice in any new SCSI designs, or 
upgrades requiring increased performance. For users not 
wishing to make the software changes, required to utilize 
the enhanced features of the DP8490, the DP5380 is avail- 
able, offering speed and power improvements over existing 
parts, at a highly competitive cost. Every user that has tried 
replacing existing NMOS 5380s with either the DP5380 or 
DP8490, at both ends of their existing application, have ex- 
perienced data transfer speed improvements of between 
10% and 15%. That is with no other changes! 
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A SCSI Printer Controller 
Using Either the 

DP8490 EASI or 

DP5380 ASI and 

Users Guide 


The DP8490 Enhanced Asynchronous SCSI Interface and 


DP5380 Asynchronous SCSI Interface are CMOS devices, 


which offer a low cost high performance Small Computer 
Systems Interface. These devices are pin compatible, and 
software compatible until an enhanced mode bit is set in the 
DP8490. This enhanced mode offers many new features 
which can yield increases in system performance through 
software, in addition to the improvements in speed and 
power shown by both devices over existing NMOS devices. 


This application note shows how the hardware and software 
can be designed for a SCS! Printer Controller (SPC) so that 
it can incorporate either the DP5380 or DP8490. Since the 
software automatically detects which device is inserted ei- 
ther can be used, although the enhanced mode of the 
DP8490 offers a better system in terms of throughput and 
error tolerance. All of the software discussed is available on 
a floppy disk. 


16 bit address bus 


processor 
8 bit data bus 


memory 
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1.0 Introduction 
The SCSI Printer Controller (Figure 7.7) consists of five 
main parts: 
1. Microprocessor NSC800™ 
2. Printer Interface NSC831 PIO (Parallel Input/Output) 
3. SCSI Interface DP8490 or DP5380 
4, Memory 
CMOS EPROM NMC27C256 
CMOS Static RAM 62256 
5. DMA Controller 9517 or 8237 


The NSC800 is an eight bit CMOS microprocessor which is 
the central processing unit of the National Semiconductor 


Printer 
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SCSI bus 
Interface 
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FIGURE 1.1 


1.0 Introduction (Continued) 


NSC800 microcomputer family. It is capable of addressing 
64 kbytes of memory and 256 I/O devices using a multi- 
plexed address and data bus. The instruction set is fully 
compatible with that of the Z80. 


The NSC831 is the parallel input/output (PIO) device of the 
NSC800 family. This provides 20 I/O bits which can be indi- 
vidually programmed to be inputs or outputs. These are con- 
figured as two eight bit ports and one four bit port. The PIO 
is used as the interface between the microprocessor and 
the printer. 


The DP5380 and DP8490 comply with the ANS X3.131- 
1986 SCSI standard as defined by the ANSI X3T9.2 commit- 
tee. They can act as both Initiator and Target supporting all 
bus phases. Due to the on-chip high-current open-drain driv- 
ers the devices interface directly to the SCSI bus. 


The 64 kbyte memory space is split between a 32 kbyte 
EPROM, containing the run-time software, and a 32 kbyte 
static RAM. 


Data transfers between memory and the EASI can be con- 
trolled by the DMA controller, which supplies all read and 
write strobes for a transfer in either direction. This is a syn- 
chronous device which uses the 4 MHz clock output from 
the microprocessor. 


The microprocessor is normally in control of the internal 
busses, giving it the ability to read or write memory or I/O 
devices. During a DMA transfer the DMA takes control of 
these busses and can pass data between the EAS! and 
memory. As the microprocessor is the only device with ‘in- 
telligence’ it must control these transfers. It commences 
and controls operations by setting registers in the DMA and 
EASI. 


2.0 Hardware 
2.1 DEVICES 


2.1.1 Introduction 


This section is intended to explain the hardware of the SPC 
referring to the circuit diagram given in Appendix A. This will 
describe the devices used and the signals generated but 
not the way in which they are programmed. What will be 
discussed is how the devices-relate to each other, their rela- 
tive timings, and any extra hardware required. A more exact 
description of the internal registers of the EASI, DMA and 
PIO, and their operation, will be given in the diagnostics 
section. 


2.1.2 Microprocessor 


The NSC800 is an eight bit microprocessor which multiplex- 
es the eight bit data bus with the lower half of the address 
bus to create a sixteen bit address bus. An octal latch, 
MM74HCT373, is required to hold the address on the bus 
during a memory read or write, with the ALE (Address Latch 
Enable) output from the NSC800 strobing the latch. 


Since the bus has devices which use both TTL and CMOS 
levels pull-up resistors are required. The IOM output signi- 
fies whether the processor is on a memory or an I/O cycle 
and is used along with the RD and WR outputs to strobe bus 
data. es a Eu 

This processor allows control of the bus to be passed to an 
I/O device, using the BRQ (bus request) input and BACK 
(bus acknowledge) output. On this board the DMA is the 
only device which may request control of the bus. 
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When the EASI issues a DMA request the DMA signals that 
it needs control of the bus by issuing a BRQ. The processor 
acknowledges this by issuing BACK, and then drives the 
bus and all related control signals to their high impedance 
state. The MM74HCT373 must TRI-STATE® its outputs; the 
output enable is driven by the DMA signal AEN (address 
enable), which it asserts when it has contro! of the bus. At 
the end of its operations the DMA releases AEN (enabling 
the latch outputs) and negates BRQ. The processor de-as- 
serts BACK and retakes control of the bus by enabling its 
outputs. To prevent spurious signals being generated when 
the bus is not driven the control signals must have pull-up 
resistors. 


The NSC800 provides five hardware interrupts of which only 
RSTA is used. The others are tied inactive. RSTA is driven 
by the EASI interrupt output, with an inversion between 
them to allow for the difference in active levels. An interrupt 
on this pin causes a software reset to a particular address in 
memory (more details of interrupt servicing will be given in 
the diagnostic software section). 


The system clock is generated using an 8 MHz crystal, with 
the frequency divided by two for use by the processor and 
the DMA. There is also power-on reset circuitry, which re- 
sets the processor, and causes a reset output to the other 
devices when power is first applied. 


2.1.3 DMA Controller 


The 9517 and 8237 are compatible direct memory access 
devices, controlled by setting internal registers. These regis- 
ters are selected using a chip select, with the particular reg- 
ister selected by the lower nibble of the address bus, and 
data strobed by IOR (I/O read) or IOW (I/O write). These 
registers control the type of data transfer, the number of 
bytes transferred and the memory address’ the transfer is 
to/from. 


The two modes of transfer used are single mode and block 
mode. In single mode the DRQ (DMA request) input and the 
DACK (DMA acknowledge) output are used to ‘“‘handshake”’ 
every byte of data transferred. In block mode, after an initial 
DRQ, DACK must be active until after the last byte has been 
transferred. The rate of transfer is controlled by the READY 
input. 

Another device required in conjunction with the DMA is an 
MM74HCT74 ‘D’ type flip-flop. This is used to overcome the 
metastability problem introduced by the asynchronous 
READY signal driving a synchronous device. The flip-flop 
synchronizes the input with the system clock. 


The DMA supplies all the necessary control signals to move 
data from memory to EASI or vice-versa. When all data has 
been transferred the DMA drives EOP (end of process) ac- 
tive. EOP can also be-used as an input to the DMA, prema- 
turely terminating. any transfer. It is configured as an open- 
drain driver, so requires a pull-up resistor, of an advised 
value of 4.7 kN. 


As in the processor the DMA has a multiplexed address and 
data bus, also requiring an MM74HCT373 to latch the ad- 
dress. In this case it is the upper byte of the address bus 
which is multiplexed with the data bus. The strobe signal is 
similar to ALE but is generated in the DMA and called 
ADSTB (address strobe). The TRI-STATE for this latch is 
driven by the inverse of AEN, since the device must drive 
the bus only when the DMA has control. 


€9S-NV 


AN-563 


2.0 Hardware (Continued) 


The 9517 and 8237 have four DMA channels, of which only 
one is used. The DRQ inputs for the other three channels 
are tied inactive. The RESET input causes the control regis- 
ters to be cleared and the DRQ inputs to be masked. 


2.1.4 EASI 


The EASI is controlled by setting internal registers, written 
by an IOW and chip select, read by an IOR and chip select. 
The particular register selected is determined by the lowest 
three bytes of the address bus. The EASI has an eight bit 
microprocessor data bus, and on the PLCC part a micro- 
processor bus parity pin. However the NSC800 does not 
support parity checking so this bit is tied low. The other 
microprocessor controlled pin is the RESET. This causes 
the EASI to clear all registers and therefore reset all logic. 


The DRQ output and DACK input “handshake” single mode 
DMA, while the READY output is used to control the speed 
of a block mode transfer. EOP is an input which terminates 
DMA, and can be used to cause an interrupt. This interrupt 
output INT can interrupt the microprocessor if the EAS! de- 
tects an error, or has completed some task. 


SCSI uses an eight bit data bus with a parity bit; which must 
support odd parity during all bus transactions except arbitra- 
tion. Other SCSI signals are the bus selection control sig- 
nals SEL and BSY, phase control signals MSG, C/D and 
170, data transfer handshakes REQ and ACK and the mes- 
sage flag ATN. Further details on the use of these signals 
will be given in the software sections of this document. The 
SCSI reset RST is similar to a chip reset, but generates an 
interrupt. 


The EAS! interfaces directly to the SCSI! bus using high-cur- 
rent open-drain drivers. This bus is a 50-way ribbon cable 
(maximum length 6.0 meters) on which all SCSI devices are 
daisy-chained. The devices at the end of this cable must 
terminate the SCSI signals i.e., a 2200 resistor to power, 
and a 3309 to ground. This power can be Vcc or 
TERMPWR (terminator power). 


TERMPWR is Vcc fed through a Schottky barrier diode. 
This can be fed to pin 26 of the connector allowing the SCSI 
device at one end of the bus to be powered down without 
affecting the bus. Since the terminators are receiving power 
the bus can operate effectively. To make this optional 
TERMPWR is fed to the connector through a jumper link. 
The Schottky diode must be included to prevent backflow of 
power into the printer controller board. 


Other manufacturers CMOS devices can not be used in 
a configuration like this, as they pull the bus low when 
not powered. The DP5380 and DP8490 have a special 
input protection to overcome this problem. 


All other pins on the connector should be tied to ground, 
except pin 25 which must be left floating. 


2.1.5 PIO 


The printer controller uses a NSC831 PIO to interface be- 
tween the processor and the printer. The NSC831 has 20 
individually, programmable |/O bits which are arranged as 
three ports; A, B and C. As it is part of the NSC800 family 
the NSC831 has a compatible multiplexed address and data 
bus with an ALE input, to strobe the address into an internal 


latch. This eight bit address can then be used to access an 
internal register, in conjunction with an IOR or IOW and chip 
select. The device has two chip selects, one of which is tied 
active (low), with the other coming from the address decode 
PAL®. The RESET input causes the three ports to become 
all inputs. - 


In this application the three ports are set up so that each 
port is all input or all output. Port A is an output, which drives 
the printer data bus through an MM74HCT241 octal buffer. 
Port B is an input, with the lower nibble coming from the 
printer outputs, driven by half an MM74HCT240 octal invert- 
ing buffer. The pull-down resistors on the ERROR and PE 
(paper error) inputs give a proper error signal if the. printer is 
unconnected i.e., the same as when the printer is off-line. 
The upper three bytes of Port B are connected to switches, 
which are used to set the board’s SCSI I.D. This will be 
further explained in the SCSI diagnostics section. Only three 
bytes of Port C are used, all as outputs, driven by the same 
device used by Port B. Bits 0 and 2 are printer outputs, while 
bit 3 drives a LED. This displays the ‘health’ of the board 
i.e., when the board is operational the LED is on, when non- 
operational it is off and when there is a known hardware 
error a message is ‘flashed’. 


The printer connector is a standard IBM® 25 way ‘D’ range, 
with all unused pins grounded, except 13. 


2.2 PAL EQUATIONS 


2.2.1 Introduction 


PAL’s are used in this board to generate chip selects, over- 
come potential timing problems and to invert signals for de- 
vices with different active levels. The PAL’s used are Na- 
tional Semiconductor’s PAL16L8. The equations are written 
in a form compatible with PLAN (Programmable Logic Anal- 
ysis by National) Ver. 2.00. 


2.2.2 Decode PAL 


The decode PAL supplies the five main devices with their 
chip selects. 


Memory is split into two 32k byte blocks, each of which 
represents one device. These devices are an EPROM, at 
the base of memory, and RAM in the upper half. Thus the 
memory map and chip select equations are as follows: 


FFFFh 


8000h 
7FFFh 


0000h 


/EPROMZ = /A15*BACKZ*/IOMZ 
/RAMZ = A15*BACKZ*/IOMZ + A15 * AEN 


EPROMZ (the Z at the end of the name shows it is active 
low) can only be selected by the processor, while RAMZ is 
available to the DMA. 
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2.0 Hardware (Continued) 


The DMA, PIO and EASI fit into the 1/O map shown, which 
results in the equations following. These equations show 
that the devices can only be selected by the microprocessor 
on an I/O cycle. 


FFh 


20h 


00h 


/EASIZ = /A7 * /A6 * /A5 * IOMZ * BACKZ 
/DMAZ = /A7 * /A6 * A5 * IOMZ * BACKZ 
/PIOZ = A7 * /A6 * /A5 * IOMZ * BACKZ 
The other three outputs are used as inverters: 
/BRQZ = HRQ : 
/AENOZ = AEN 
/HLDA = BACKZ 
The two spare inputs are tied low. 


2.2.3 Control PAL 


The NSC800 uses IOM to distinguish between memory and 
I/O cycles. This allows [OR and IOW, for processor cycles 
to be generated. 


NORZ = /RDZ * IOMZ 
IORZ.TRST = BACKZ 


NOWZ = /WRZ * |OMZ 
lOWZ.TRST = BACKZ 


The second line of these equations shows that the output is 
TRI-STATE when the processor relinquishes control of the 
bus. 


Before examining the next five equations it is important to 
fully understand the relative signal sequencing involved ina 
DMA transfer. When the transfer is initiated the EAS! issues 
a DRQ, causing the DMA to respond with DACK, and take 
control of the bus by asserting BRQ. The processor asserts 
BACK and allows the bus and relevant control signals to go 
TRI-STATE. The DMA then asserts AEN, to show it is in 
control of the bus, causing the microprocessor address 
latch to TRI-STATE its outputs and the DMA latch to enable 
its outputs. 


For single mode each byte transferred must have a DRQ 
and a DACK. For block mode DRQ returns inactive after the 
DMA responds with a DACK, but the DACK must remain 
active until the transfer is complete. The READY line con- 
trols the rate of block mode DMA transfer i.e., when READY 
is low the byte transfer is ‘frozen’, until READY returns high 
(Figures 2.1a and 2.76). 


The READY signal is asynchronous but the DMA is synchro- 
nous, testing the READY signal on the negative edge of 
each clock. For this reason the READY input must be syn- 
chronized, using a flip-flop which updates its output on the 
positive edge of the clock. 


When READY is detected as being inactive on the negative 
edge of the clock an extra cycle is inserted to the read and 
write. 


While data is being transferred a register keeps track of how 
many bytes are left. When this reaches zero an EOP signal 
is generated, concurrent with the last read and write, caus- 
ing the EASI to set an EOP flag. 


READ* l [ 
WRITE* i ; 


READY | [ 


TL/F/10082-2 


FIGURE 2.1a 


READ* i 
WRITE* [ 


READY 


TL/F/10082-3 


FIGURE 2.1b 


*Note: 


Of these read and write signals, one will refer to memory the other |/O, depending on the direction of data transfer. 
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2.0 Hardware (Continued) 


The tranfer is now complete so BRQ, AEN and DACK are all 
driven inactive. AEN going inactive causes the address 
latches to swop back over; the microprocessor latch out- 
puts are driven, the DMA latch outputs are TRI-STATE. 
When the microprocessor detects that BRQ is inactive it 
deasserts BACK and retakes control of the bus. The micro- 
processor then clecks flags in the EASI to determine the 
success, or otherwise, of the transfer. 


The other form of DMA available is pseudo-DMA,; that is the 
EASI ‘thinks’ it is a proper DMA transfer but the processor is 
still in control of the bus. To do this the microprocessor 
must set the DMA to mask off any DRQ, initialize the EASI 
for single mode DMA and monitor the EASI flags for DRQ 
going active. At this point the processor must generate an 
IOR or an IOW and a DACK, to properly simulate DMA. This 
can be done by causing an I/O read or write at a certain 
address, to generate a DACK, and if wanted an EOP. The 
particular address does not matter since during DMA the 
EASI ignores the address bus. 


The following equations generate pseudo-DMA signals, 
while allowing the true DMA signals to operate normally: 


/DACKOZ = /IORZ * BACKZ * /A7 * A6 
+ /IOWZ * BACKZ * /A7 * A6 
+ /DACKIZ 


/EOP2 = /IORZ * BACKZ * /A7 * A6 * /A5 
+ /IOWZ * BACKZ * /A7 * A6 * /A5 
+/EOP1 * EREADY 


DACKIZ is the DACK from the DMA, which the output nor- 
mally follows. The rest of the equation generates the pseu- 
do-DMA DACK. 


EOP2 is the input to the EASI, EOP1 is the output from the 
DMA. The first two lines of this equation generate an EOP 
for the pseudo-DMA cycle, on the lower half of the address 
space that also generates the pseudo DACK. This means 
the final 1/O map now is as follows: 


FFh — 
AOh a 
pseudo-DMA 

60h 

pseudo-DMA & EOP 
40h 
20h 

EAS! 

00h 


The third part of the EOP1 equation is to overcome a prob- 
lem that occurs during a block mode DMA transfer. On the 
last byte the READY signal from the EASI (this will be called 
EREADY to distinguish it from the READY into the DMA, 


DREADY) may be driven low to freeze the transfer. Howev- 


er DACK, EOP and IOR or IOW will all be active causing a 
valid EOP condition. This is not a problem until we consider 
the next equation. 


/DREADY = /EREADY * /INT * /DACKIZ 
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This equation causes the DMA READY input to go high if 
any of EREADY, SCSI interrupt INT or DACKIZ go high. This 
overcomes a potential bus lockup, caused by an error oc- 
curring during a block mode DMA transfer. On a phase or 
parity error the EASI will stop the transfer and generate an 
interrupt. If DREADY is left inactive the DMA will keep con- 
trol of the microprocessor bus. This equation holds 
DREADY high on interrupt, allowing the DMA to pass con- 
trol of the bus back to the microprocessor. 


Although this equation prevents an error it also introduces a 
problem in the EOP2 equation. As explained previously, dur- 
ing the last byte of a block mode transfer although READY 
is low a valid EOP condition may exist, which will cause an 
interrupt. This interrupt will then cause DREADY to be driv- 
en high, allowing the DMA to finish the transfer, but lose the 
last byte since the EASI is not ready. To overcome this the 
EOP2 equation gates EOP1 with EREADY, so the EASI 
does not see a valid EOP condition until it is able to transfer 
the last byte. This problem does not occur in MODE E 
since it generates a true end of DMA interrupt. 


Another problem is introduced by the DREADY equation. If 
an error occurs during a DMA transfer the EASI will gener- 
ate an interrupt and DREADY will be forced high. This al- 
lows the DMA to ‘run free’, writing garbage into MEMORY, 
and wasting SCSI bus time. To prevent this an external EOP 
must be applied to the DMA on error. The next equation 
does this: 


/EOP1 = /DACKIZ * /EREADY * INT 
EOP1.TRST = /DACKIZ * /EREADY * INT 


EOP1 is an I/O pin which normally acts as input from the 
DMA, so the output is TRI-STATE unless DACKIZ and 
EREADY are low, with INT active. When this error condition 
occurs an EOP is output to the DMA, terminating the data 
transfer. A prerequisite of this equation working properly is 
the existence of the DREADY equation, since an externally 
applied EOP will have no effect on the DMA if READY is 
held low. 


The next equation is also required to prevent a fault occur- 
ring during a block mode DMA transfer: 


/EASIWRZ = /IOWZ * BACKZ 
. +/IOWZ * EREADY * /BACKZ 


When the processor is in control of the bus a straightfor- 
ward IOW can write to the EASI, but if the DMA is in control 
EREADY must be high to’allow the write. The inclusion of 
EREADY is required because during DMA the EASI is a 
flowthrough latch; an IOW passes the data from the proces- 
sor bus onto the SCSI bus. Therefore if the DMA reaches its 
next byte before the data on the SCSI bus has been trans- 
ferred, the DMA will overwrite the data. To prevent this 
EASIWR can only be allowed when EREADY is high. 


The final PAL output is used to invert the SCSI interrupt 
signal, to make this active high output compatible with the 


processor’s active low input. 


/SCSIINTZ = INT 


3.0 Diagnostic Software 


3.1 INTRODUCTION 


The diagnostic software resides at the base of RAM, with 
the purpose of checking and initializing the printer controller 
board after power up and every hard reset. It must be at 
location zero, since after any hardware reset the program 
counter is cleared. The interrupt service routine is included 
here, since it must exist at an exact location in memory. 


oy 


3.0 Diagnostic Software (Continued) 


The software uses the NSC800 instruction set (fully Z80® 
compatible) which makes the required low level board oper- 
ations faster, and allows the exact positioning of code in 
memory. The assembler and linking loader are from Micro- 
tec Research. 


3.2 DEVICE CHECKING AND INITIALIZATION 


This section will refer to the diagnostic software 
PRINTER.SRC and the files PRNSYM.SRC and 
EASISYM.SRC which contain the constants used. A full list- 
ing of all programs described in this document are available 
on floppy disk. 


3.2.1 Memory Check and Interrupt Servicing 


An ‘org’ statement can be used to position this program at 
the base of ROM, address 0. After a jump to the ROM 
check, the next byte stores a label defining which version of 
the software is installed. On an EPROM the version number 
can be read from address 0002h. The upper and lower nib- 
bles should be considered as two numbers i.e., ‘10’ defines 
version 1.0. 


The interrupts are disabled, since the service routines are 
not initialized, and the EPROM is checked; simply consisting 
of reading the same address twice and ensuring the same 
value returns both times. If this test fails the system halts 
since a drastic error must have occurred. If the EPROM 
passes the test the program jumps to the RAM check. 


On interrupt the NSC800 stops before its next instruction, 
pushes the program counter onto the stack and loads it with 
a new address, depending on the highest priority interrupt 
channel active. Interrupt A, the only channel used, causes a 
jump to location 003Ch. The interrupt service routine at this 
location pushes all of the processor registers onto the 
stack, and tests for a SCSI reset. SCS! reset must be 
checked, as this is a special condition, causing the board to 
be reset by a general restart routine (this routine is in EAS- 
1O.SRC and explained in section 3.5). 


If the interrupt is not a SCSI reset the software makes a call 
to the bottom of RAM, where a jump command should be 
followed by a public variable RESETA. This variable can be 
loaded with the starting address of the routine to service the 
interrupt. On return from this routine the processor registers 
are popped back off the stack, and program control returns 
from the interrupt. Since RESETA is public any external 
software may use it, and therefore control which routine 
services an interrupt. RAM must be verified before this jump 
table is set up. 


The RAM test simply checks each BIT can contain a zero 
and a one, then clears every byte. Once RAM has been 
verified the stack pointer may be initialized, allowing call 
statements to be included. It should be remembered that 
although the interrupt routine is between the ROM and RAM 
tests, when the program runs it will jump straight from the 
ROM test to the RAM test. Since the interrupt jump table is 
in volatile RAM the code for a jump instruction must be writ- 
ten into RAM after every reset. 


3.2.2 PIO Initialization 

The file PRNSYM.SRC contains the port addresses for all of 
the 1/O devices, The upper nibble contains the location the 
device takes within the |/O map, the lower nibble selects 
the register within the device to be accessed. 
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The PIO has five types of registers which control data trans- 
fers through the device: 


1. Data Register—Each port has an eight bit data register 
containing the data passed between the PIO and the 
processor. These are either read or write registers, de- 
pending on whether the port bits are inputs or outputs. 


2. Data Direction Registers—Each port also has a data 
direction register which controls whether each of the 20 
bits is an input or an output (an input is defined by a zero, 
an output by a one). 


3. Mode Register—There is one three bit mode register 
which selects which of the four modes the device is in. 
This board will always require the PIO to be. in Mode 0 
which is the basic |/O mode. The alternatives use Port C 
for handshaking. 


4. Bit Clear Register—Each port has an eight bit, bit clear 
register which clears any output bit whose corresponding 
bit in this register is high. 

5. Bit Set Register—These are similar to the above, but 
allow the output bits to be set. 


The PIO is set for Mode 0, with Ports A and C outputs and 
Port B an input. Port A drives the printer data bus, while 
Ports B and C read and write the printer control signals. The 
four printer outputs, to the Port B input, are ACK, BUSY, PE 
and ERROR. ERROR goes low when there is no paper, the 
printer is off-line or an error occurs; PE goes high when the 
printer is out of paper; BUSY goes high to show the printer 
can accept data; ACK pulses low to acknowledge data after 
a byte has been transferred. Since BUSY and ACK are both 
handshake signals the user must decide which to use. This 
software will use BUSY. 


The top three bytes of Port B are used to read in the SCSIID 
from a block of switches. The SCSIID is the boards identifier 
on the SCSI bus, used in selection and arbitration, consist- 
ing of a single active bit. This is read in as a three bit num- 
ber, converted to the correct bit pattern and stored in a 
public variable called SCSIID. 


Port C is an output, driving the printer signals INIT and 
STROBE. A low pulse on INIT of 50 xs causes the printer to 
be initialized; a 500 ns low pulse on STROBE causes the 
printer to read the data on the bus. The highest bit of Port C 
drives a LED, which is on during board operation, and can 
display an error message by occulting a fixed code. Errors 
are displayed by the routine ERROR, a public function which 
displays the error number as a four bit code. It does this by 
occulting the LED for 1 second to show a 1, 1% a second for 
aQ. - 


Since none of the PIO registers are true read/write the de- 
vice cannot be tested, only initialized. 


3.2.3 DMA Test and Initialization 


The DMA consists of address, word-count and control regis- 
ters for four channels, of which only one is used. There 
follows a description of the registers used, with the address- 
es shown in PRNSYM.SRC. 


1. Word-Count Registers—There are two word-count reg- 
isters; a sixteen bit write only base word-count register 
and a sixteen bit read only current word-count register. As 
with all sixteen bit registers in this device the two bytes of 
data are accessed by two successive selections of the 
same address. An internal flip-flop determines which byte 
is read or written, with the lower byte selected first after a 
reset. To transfer the correct number of bytes the word- 
count register must be written with the number of bytes to 
be transferred minus one. 
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3.0 Diagnostic Software (continued) 


2. Address Registers—The address registers are also six- 
teen bit, and called base and current. The base address 
register is written with the address the transfer must start 
at, while the current address register contains the next 
address to be written or read. The DMA is tested by writ- 
ing a value to the base address and reading it back from 
the current address. 


3. Control Registers—There are three types of control reg- 
ister which will be discussed only in the way they are used 
by this software. The master clear register (DMAMCL) is 
the software equivalent of a hardware reset; all registers 
are cleared and DRQ is masked off. Masking of DRQ is 
controlled by the parallel mask register (DMAMSk), in 
this case always used to allow DRQ on Channel 0 and 
mask off the others. The final type of register used is the 
mode register (DMAMOD) which controls whether a 
transfer is block or single mode, memory read or memory 
write. Each of the four channels has a six bit mode regis- 
ter, all at the same address, with the bottom two bits of 
the data bus determining which is selected. 


The DMA test program initializes the device for a one byte, 
block mode, memory write, to an address TSTBYT. The 
DMA is initialized in this particular manner for use in the 
EAS! loopback DMA test routine. 


An error in DMA test will cause error signal 0. 
3.3 EASI TEST AND INITIALIZATION 


3.3.1 Introduction 


This document will show how the registers within the 
DP5380 and DP8490 are used in an application. For a full 
register description refer to the DP5380 and DP8490 data- 
sheets. Register names and their locations are given in 
PRNSYM.SRC. 


3.3.2 DP8490 and DP5380 Test 


The DP5380 and DP8490 are completely pin and hardware 
compatible, and also software compatible until the en- 
hanced mode bit is set in the DP8490. The DP8490 powers 
up in normal mode (MODE N which is software compatible 
with the 5380) and is in MODE N after any chip reset. The 
initial test is therefore the same for both devices, writing to 
the Mode Register 2 (EASIMR2) and reading back the data. 
The EASIMR2 is selected since it has the most read/write 
bits that do not directly affect the bus. 


An error in EASI test will cause error signal 1. 


For the DP5380 testing is now complete, but the DP8490 
enhanced mode offers a loopback test facility, where the 
SCSI drivers are disabled and the SCSI I/O’s looped back 
inside the EASI. Using this feature the user can fully 
check the device, and by doing a DMA transfer fully 
check the board. 


At this stage it is therefore neccessary to determine which 
device is inserted. In the DP5380 bit 6 of the Initiator Com- 
mand Register (EASIICR) selects the ‘test mode’, which dis- 
ables all output drivers on the device, making it invisible to 
the system. Although the device can still be written to no 
data can be read back, making applications very limited. In 
the DP8490 this bit selects the enhanced mode (MODE E) 
of the device. 


In MODE E addresses 0-6 access the same registers as in 
MODE N, but address 7 is different. Instead of accessing 
the Reset Parity/Interrupt (EASIRP!) and Start DMA Initiator 
receive (EASISDI) registers, address 7 directly accesses the 


4-88 


Enhanced Mode Register (EASIEMR) and indirectly access- 
es the Interrupt Mask Register (EASIIMR) ‘and Interrupt 
Status. Register (EASIISR). The only other difference to reg- 
isters occurs in the Target Command Register. (EASITCR) 
where one of the previously unused bits becomes a flag 
(explained in section 3.3.4). — 


To test which device is inserted EASI test sets the en- 
hanced/test mode bit, writes data to address 7 and. reads 
back from the same address. If the device is a DP5380 it will 
be in ‘test mode’ and the data read will be OFFh due to the 
pull-up resistors on the data bus. If it is a DP8490 the data 
read back will be the data written, providing the only bits set 
are read/write. For a DP5380 the program jumps to initiali- 
zation for selection; if it is a DP8490 loopback pee fol- 
lows. , 


3.3.3 DP5380 Initialization for Selection 


The DP5380 initialization involves programming the device 
to respond to a selection. First, the public variable DP8490 
(which other programs should treat as a constant) is set 
FALSE to indicate that a DP8490 is not inserted. For the 
DP5380 to be selected it must have the SCSIID of the de- 
vice in its Select Enable Register (EASISER) and parity 
must be enabled. The processor must enable its interrupts 
and set up the jump table; /ntA is an external routine which 
sets the processor’s interrupt mask to only allow interrupts 
on A, and enables the interrupts (see EASIO.SRC); main 
is an external program which responds to a SCSI selection 
(further explained in the Run-time software section). 


If BSY is inactive for a bus settle delay (400 ns), SEL is true 
and the bit on the data bus corresponding to the SCSIID is 
active, a SCSI selection interrupt is generated. This causes 
a processor interrupt, taking the program from the continu- 
ous ‘jr Now’ instruction to the interrupt service routine, and 
through the jump table to main__.. When main__ has finished 
servicing the interrupt it will return to the interrupt servicing 
routine and then return from the interrupt. Thus the board’s 
‘idle’ state is to continually execute the ‘jr Now’ instruction. 


3.3.4 DP8490 Loopback Test 


The loopback test mode of the DP8490 allows all signals to 
be fully tested, including a DMA transfer, without affecting 
the SCSI bus. To allow this DMA transfer loopback allows 
the user to drive both initiator and target signals simulta- 
neously. 


After setting the DP8490 flag true all initiator signals, and 
then target signals, are asserted and checked. This includes 
a check on the data bus by writing a test value to it and 
reading it back. The data bus test value has an odd number 
of bits, and since the specified SCSI parity is ODD, the parity 
bit must be inactive. One of the new features offered in 
MODE E is programmable SCSI parity, which is tested by 
ensuring the parity bit becomes. active when EVEN parity is 
enabled, and inactive when a test value with an even num- 
ber of active bits is written. Parity is then returned ODD, and 
the parity bit should become active. 


An error in Loopback testing causes error signal 2. 


The next test in loopback mode is a DMA target receive 
transfer to a location in memory, TSTBYT. This not only 
tests the EASI, but also the interrupt servicing, the DMA and 
memory. Although the device is in loopback the software 
must carry out the transfer as it would normally i.e., the bus 
phase must be correct, BSY must be active and the SCSI 
bus must be asserted. The EASIMR2 must be properly set 
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3.0 Diagnostic Software (Continued 


up for block mode DMA, with interrupt on EOP or parity 
error. Since this test is interrupt driven the interrupt jump 
table must be loaded with the address of the routine which 
will service the DMA loopback test, and the interrupts must 
be enabled. The DMA has already been initialized for this. 


Before enabling interrupts the SCSI interrupts should be re- 
set, which in MODE N would involve reading address 7. 
Since the EASIEMR is now at this address the resetting of 
interrupts, and the start of DMA initiator receive are initiated 
by writing to function bits of the EASIEMR. 


When the Start DMA Target receive (EASISDT) register is 
written the EASI will issue a REQ to show it is ready to 
receive data on the SCSI bus. At this point the device at the 
other end of the bus would normally assert ACK to show it 
has data available. In this case there is no other device so 
the user must wait for REQ to go active and then assert 
ACK. Thus both initiator and target signals must be asserted 
simultaneously. The user waits for REQ to go inactive, and 
deasserts ACK to show the bus transfer is complete. 


The program then goes into a continuous loop awaiting a 
SCSI interrupt. This interrupt will occur because the EASI 
will have issued a DRQ, when ACK went active, and the 
DMA wil have transferred the last test byte written to the 
EAS! to TSTBYT, finishing with an EOP. On interrupt the 
program will jump to address 003Ch, where ail the proces- 
sor registers are pushed onto the stack, a call is made to 
the base of RAM, and from there it will jump to the subrou- 
tine DIAGA. 


One of the problems with DMA in a DP5380 is that end of 
DMA is flagged when DACK, EOP and IOR or IOW are 
simultaneously active; although the data may not yet have 
been transferred on the SCSI bus. To overcome this the 
software must examine the SCSI handshake signals REQ 
and ACK, both of which must be inactive on three succes- 
sive samples for a true end of DMA. This is more fully ex- 
plained in the DP5380 and DP8490 datasheets. MODE E of 
the DP8490 detects true end of DMA, after ACK goes 
inactive, before generating an interrupt. 


DIAGA responds to the interrupt after the loopback DMA by 
checking all the correct flags have been set. The DP5380 
only uses four bits of EASITCR so MODE E uses the free bit 
7 as a flag, to show true end of DMA. This is the first flag 
checked. Address 7 not only directly addresses the 
EASIEMR it also indirectly addresses the EASIIMR and 
EASIISR. After writing the correct code to the function bits 
of the EASIEMR the next access of address 7 will be to the 
EASIISR, if it is a read, or the EASIIMR, if it is a write. The 
advantage of the EASIISR over the DP5380 registers is 
that all interrupt information is available in one register, 
and every interrupt is flagged. To check DMA the user 
need only read the EASIISR and ensure that the only flag 
active is end of DMA. The user should note that SCSI reset 
causes the device to revert to MODE N, from which the 
EASIISR can not be read, so is not flagged. 


The final EASI flag test is the ‘conventional’ end of DMA 
flag in the Bus and Status Register (EASIBSR). This flag, 
the interrupt flag and the flag to show no phase mismatch 
has occurred must be the only bits active. The final loop- 
back DMA test is to ensure that memory location TSTBYT 
contains the correct data. 


An error in Loopback DMA test causes error signal 3. 
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3.3.5 DP8490 Initialization for Selection 


The DP8490 initialization is very similar to that of the 5380, 
even Calling the same routine, main__, to respond to selec- 
tion. However, this device stays in MODE E and uses these 
enhancements to only allow interrupts on selection and par- 
ity by setting the EASIIMR. Selection and parity are the only 
valid interrupts at this point. 


At the end of the DIAGA routine program control returns to 
the ‘jr Here’ instruction, which it will continually enact until a 
parity or selection interrupt causes a jump to main__. 


3.4 ERROR HANDLING 


Throughout all software for this board the error handling is 
the same for errors considered non-recoverable, which in- 
cludes all errors in diagnostics. On error the board continu- 
ally displays an error number, as a four bit binary code, us- 
ing the LED. The subroutine ERROR carries out this func- 
tion. 


On error register ‘I’ should be loaded with the error number 
and routine ERROR called. This routine then occults the 
LED for % second to display a zero, 1 second to display a 
one, with the LED on for 14 second between flashes. The 
four bits, most significant bit first, are. repeatedly displayed 
between 2 second intervals, during which time the LED is 
on. The timing delays are generated using a routine DELAY, 
which gives a number of 1/4, second delays, the number of 
delays being determined by the value in the ‘I’ register. 


The following list shows the possible errors in diagnostics. 
The run-time software section contains a similar listing of its 
error codes. 


Error 0 
The DMA can not be accessed. 


Error 1 
The EASI can not be accessed. 


All other diagnostic errors concern a DP8490 


Error 2 
An error has occurred in the assertion of SCSI signals in 
loopback test mode. 


Error 3 
An error has occurred during the loopback DMA transfer. 


3.5 EASIO.SRC 


This file contains public assembly language routines, which 
can be called by either the diagnostics or run-time software, 
to implement low level commands. As these routines may 
need to be called by routines written in ‘C’ any variables 
passed to the routines are passed in the ‘hl’ register pair, 
then in ‘de’, then ‘bce’ and then on the stack. ERROR and 
DELAY both use the ‘l’ register to pass a variable. Data 
passed back to the calling routine is returned in the accumu- 
lator. 


Functions ‘ead’ and ‘write’ implement general purpose I/O 
register accesses, while ‘dmaread’ and ‘dmawrite’ ‘handle 
the special case of the 16-bit DMA registers. These require 
two accesses of the same address. ‘intA’ initializes the 
processor interrupt mask, with a ‘pseudo’ I/O write, which 
selects a register internal to the processor, setting the mask 
to only allow interrupts on RSTA. This function also enables 
the interrupts, which can be done by ‘en/’, with ‘ds/’ dis- 
abling interrupts. 


/Dtest’ is used by the run-time software, during selection, to 
read the number of bits active on the bus. This routine 
checks the number of high bits in the byte passed in the ‘I’ 
register, returning the value in the accumulator. 
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3.0 Diagnostic Software (Continued) 


Function ‘resirt’ is a general purpose reset routine, which 
can be called on an error condition. This causes every de- 
vice on the board to be reset, and the diagnostics to be re- 
run, thus clearing all memory and reinitializing the stack. 


4.0 Run-Time Software 


4.1 INTRODUCTION 


Following the diagnostic software must be a program which 
will control all SCS! bus transfers, beginning with selection. 
This program is written in ‘C’, using a PARAGON ‘C’ cross 
compiler for an NSC800. The relevant files for this section 
are SCSI.C, COMMAND.LIB, PROCESS.LIB, DMA.LIB, 
PRINT.LIB, ARBITRAT.LIB, SYM.H, CONST.H and COM- 
MANDS.H, all of which are on the supplied floppy disk. 


SCSI.C contains the main program, called ‘main’ by ‘C’ and 
‘main...’ by assembler. The ‘.LIB’ files contain the functions 
called by main and the ‘.H’ files contain the constant values 
used by all of these files. 


4.2 MANDATORY PHASES 


This section outlines all the bus phases and transfers which 
a target must support. It would be perfectly legal for a target 
to respond to a selection, fetch a command block from the 
initiator, and then returns status and message bytes before 
releasing the bus. Although no process would be actuated 
this would be a legal sucession of events. 


4.2.1 Selection Response 


main() is the program jumped to when an interrupt is gener- 
ated as the program circles the continuous loop at the end 
of diagnostics. This routine should only be entered after a 
selection interrupt, if any other interrupt is active it is consid- 
ered an error. The function se/ect() checks an interrupt to 
ensure it is valid. 


The type of device installed is checked by reading the 
‘DP8490’ flag, and this determines how the interrupt is veri- 
fied. In a DP5380 a selection interrupt is determined by the 
absence of any other interrupt, with SEL active. The user 
must check the EASIBSR to ensure that no error flags are 
active, only the INT and PHSM (phase match) bits. 


Any other flag will cause error number 4 to be displayed. 


After reading the EASIBSR and finding no interrupt flags the 
user knows the interrupt should be a selection. The only 
other unflagged interrupt is a reset, which would have been 
handled by the low level interrupt service routine. Therefore 
the EASICSB register must also be read, and if SEL is inac- 
tive an error condition exists. 


This causes error number 5 to be displayed. 


In MODE E the user need only read the EASIISR to de- 
termine which interrupt is active, including selection. All 
interrupts, other than parity and selection, should be 
masked off, so any error concerns only these two flags. | 


A SCSI parity error is displayed as error number 8, if the 
selection flag is not active error number 9 is displayed. 


The common tests for MODES E and N both concern the 
EASICSD; error 6 shows that the correct SCSIID bit was not 
active on the bus; error 7 shows there was more than two 
bits active on the bus. During selection an initiator is only 
allowed to assert two bits on the bus, its own ID and the 
target ID. . 
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The target must assert BSY to show it has recognized the 
selection, then when the initiator deasserts SEL the selec- 
tion phase is complete. 


4.2.2 Command Phase 


A selection phase is followed by a command phase, where 
the target reads a command block from the initiator. This 
command block specifies the actions the initiator requires 
the target to execute, plus the length of any data transfers 
requested. This board only allows six byte command blocks, 
which are transferred into the target by function fetch_ 
cmd). 


The command block is transferred using programmed |/O; 
that is each byte is individually handshaken under processor 
control. The bus phase must be Command Out (out and in 
always refer to the initiator, so Command Out is a command 
block sent by the initiator), bus phase being set in the 
EASITCR. To transfer a byte (see Figure 4.7) the user must 
assert REQ, then wait for ACK to go active to show data is 
available. On ACK the target can read the data on the bus, 
then deassert REQ to show it has received the data. When 
the initiator deasserts ACK the byte transfer is complete. 


4.2.3 Status Phase 


The target must send a status byte to the initiator during the 
status phase, at the termination of each command. A list of 
status codes is given in COMMANDS.H. sfatus() is the 
function which enters a Status In phase, and transfers the 
code. 


The EASITCR must be written with the Status In phase and 
the EASIODR with the status code. This code should be 
asserted onto the bus, remembering to keep BSY asserted, 
and if neccessary the MODE E bit. REQ is then asserted to 
show data is available. The initiator should assert ACK when 
it has read the data, allowing the target to deassert REQ 
and take the data off the bus. The transfer is complete when 
the initiator deasserts ACK (See Figure 4.2). 
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4.0 Run-Time Software (Continue) 


4.2.4 Message Phases 


A selection must be terminated by the target entering the 
Message In phase, and sending a relevant message code 
(as listed in COMMANDS.}#). The target follows the Status 
phase with the Message In phase, usually to send the COM- 
MAND COMPLETE message. This indicates valid status ex- 
ists, so the target can release BSY to free the bus. messin() 
enters the Message In phase and sends the message using 
programmed I/O, as in status(). 


The only message which must be supported is COMMAND 
COMPLETE. If a device on the bus supports other mes- 
sages it indicates this by responding to or asserting ATN. An 
initiator asserts ATN if it has a message for the target. It is 
common for an initiator to assert ATN during selection and, 
if the target responds by entering a Message Out phase, it 
sends the IDENTIFY message. This establishes whether 
the target can respond to a greater set of messages, and 
whether the initiator supports disconnection. It shows this 
by setting bit 6 of the message. In a disk controller IDENTI- 
FY would also establish the path by including a Logical Unit 
Number (LUN), but the printer controller uses all LUN’s at 
this SCSIID. 


getmes() enters a Message Out phase and fetches a mes- 
sage using programmed I/O. Although this software only 
supports single byte messages it must be prepared to ac- 
cept messages from the initiator of up to the maximum 
length, 256 bytes. If an initiator wishes to send further bytes 
after the first it must keep ATN asserted, only deasserting 
after the final byte has been transferred. getmes() will 
handshake up to 256 bytes, after which if ATN is asserted it 
will be considered an error. Only the first byte is used in 
determining the message sent. 


The use of messages during disconnection, arbitration, re- 
selection and in error handling will be discussed in those 
sections of this document. 


4.2.5 Command Termination 


After sending status and message codes to the initiator, the 
target should then release BSY to free the SCSI bus. How- 
ever, before allowing a bus free phase the target must ini- 
tialize itself for the next selection, as in function reseft( ). 


The interrupt jump table is loaded with main() and the 
EASISER with the SCSIID. For a MODE E device the inter- 
rupt mask is set. For both types of device the interrupts 
must be reset, and BSY deasserted. Interrupts are disabled 
at the start of this function, so must be enabled after calling 
reset(). 


4.3 COMMAND PROCESSING 


After the command block has been fetched the command 
has to be determined and executed. The printer command 
set is shown in COMMANDS.H. 


process__cmd() reads the first byte of the command block 
which contains the operation code. This determines what 
actions are taken. If a command has been sent which this 
software does not recognize, a status of CHECK CONDI- 
TION is returned, with sense set to ILLEGAL REQUEST. 
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4.3.1 Test Unit Ready 


TEST UNIT READY will be sent by an initiator before a print 
to ensure the printer is on, on-line, has paper and is not in 
an error condition. On this command the function ck__print- 
er() is called to read the printer signals through Port B of 
the PIO and check for errors. 


If the error line is not high the printer is operational, so the 
status is GOOD, and the sense is set to NO SENSE (no 
error). If there is an error the paper error line must be 
checked. If this is low (active low input) the printer is out of 
paper and status of CHECK CONDITION is returned, with 
sense set to MEDIUM ERROR. If it is not a paper error the 
printer is assumed to be off or off-line, so status is CHECK 
CONDITION with sense UNIT ATTENTION. ; 


4.3.2 Request Sense 


An initiator will send a REQUEST SENSE command after 
the target has returned a status of CHECK CONDITION. 
The sense data is sent to the initiator in an effort to under- 
stand an error condition, and if possible recover from it. Byte 
4 of this command block contains the length of an extended 
sense message, which must not be greater than 4, or sense 
is set to ILLEGAL REQUEST and CHECK CONDITION 
status returned. This software only supports four bytes of 
sense data. 


Sense data is sent to the initiator using single mode DMA. 
The DMA is initialized by send__sense(); it is reset by a 
master clear, the mode set, the DMA mask written and the 
address and word-count loaded. The function single_ 
dma__in() (explained in section 4.4.1) enters the correct 
phase (Data In) and transfers the data. 


4.3.3 Reserve Unit 


In a multi-initiator system a printer controller must be re- 
served before a print commences, or the data from two dif- 
ferent initiators may be mixed. This command stores the 
initiator’s ID in a variable called ‘reserved’, and on subse- 
quent selections only this initiator may execute commands. 


Any initiator wishing to reserve the unit must put its own ID 
on the bus during selection, along with the target’s ID, so 
this software knows which initiator is reserving the unit. If 
the initiator’s ID is not on the bus it can not reserve the unit, 
and since this is a prerequisite of printing, it cannot use the 
printer. 


If an initiator attempts to reserve this unit without making its 
ID available sense is set to ILLEGAL REQUEST and status 
of CHECK CONDITION returned. If another device attempts 
to reserve the board when it is already reserved status re- 
turned is RESERVATION CONFLICT. 


4.3.4 Release Unit 


This is the reciprocal command to the previous, freeing the 
printer for other initiators after a print has been completed. If 
an initiator other than the reserver attempts this command a 
status of RESERVATION CONFLICT is returned; if this is 
attempted when there is no reservation current the returned 
status is CHECK CONDITION with sense set to ILLEGAL 
REQUEST. 
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4.0 Run-Time Software (continued) 


4.3.5 Print 


Since transferring data to a printer is a very slow process, 
typical Epson Fx range 80 cps—160 cps, the print command 
transfers the data to a buffer, leaving it to be printed later. 
Bytes 2, 3 and 4 of the command block contain the data 
length, byte 2 the most significant. The use of three bytes to 
define the size means that in theory block transfers of up to 
16 MB are allowed. This software could support blocks of 
up to 64 kB, bytes 3 and 4 are read, but blocks are limited to 
a size BUFFLIM, which will be determined in section 4.4.3. 


Possible errors in a print occur when the unit is not re- 
served, the data length is set to zero, or the block size is too 
large. The block size is too large if byte 2 of the command 
block is active or if the data length is greater than BUFFLIM. 
In response to an error the transfer is cancelled and status 
of CHECK CONDITION is returned with sense set to ILLE- 
GAL REQUEST. 


The data is not transferred unless sense is set to NO 
SENSE. If an error has occurred in the printer sense will 
have been set to indicate the error source. The error condi- 
tion must be rectified and TEST UNIT READY sent to reset 
the sense data. 


print_.cmd() is the function which transfers data into a buff- 
er using block mode DMA. The print buffer is a circular 
queue, allowing the user to take data off the front and put 
data on the rear (see Figure 4.3). 


Top 


rear 


ACTIVE QUEUE 


front 


Bottom 
FIGURE 4.3 


front points to the next byte to be printed, rear points to the 
next available byte for entering data. When front equals rear 
the queue is empty, when rear is one less than front the 
queue is full. 


The buffer limits are called top and bottom. When either the 
front or rear pointers reach the top the next increment takes 
them to the bottom. Thus the queue may look like Figure 
4.4, 
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FIGURE 4.4 


When print_cmd() is first called after a reset it must set up 
the queue, defining top and bottom, and setting front equal 
to rear equal to bottom. Before any transfer the data length 
must be checked to ensure that the DMA will not take rear 
past top. If it would the data must be transferred in two 
blocks; one to the top of the queue, and one starting at the 
bottom of the queue. This routine should not be called un- 
less there is sufficient free space for the size of transfer. 
Function ama__data() sets up the EASI and DMA for a 
block mode transfer, enters the Data Out phase and calls 
dma() to handle the transfer. This will be more fully ex- 
plained in section 4.4. 


4.3.6 Flush Buffer 


The purpose of this command is to allow an initiator to ter- 
minate an unwanted print. An initialization pulse is sent to 
the printer, in case it has its own buffer, and the SPC buffer 
is cleared. This is done by setting front equal to rear equal 
to bottom. 


4.4 DATA TRANSFERS 


This section is concerted with the way in which software 
controls DMA transfers, both block and single mode, and 
how the print data block length is determined. 


4.4.1 Single Mode DMA 


The four bytes of sense data are sent to the initiator using 
single mode DMA. send_.sense() sets up the DMA to 
transfer four bytes of data from the sense buffer to the 
EASI, leaving function single_dma_in() to complete the 
transfer. 


The phase, which in this case is Data In, is determined by 
the calling function, and the EASIMR2 initialized for a single 
mode transfer. Parity checking is enabled with interrupt on 
EOP or parity error. The data bus is asserted and the routine 
dma() is called to handle the transfer. 


Since both single and block mode DMA transfers, either in 
or out of the initiator, have large portions of code that are 
common, a function can be written for general purpose 
DMA handling. This function, dma(), sets up the interrupt 
response and makes a write to the register which initiates 
the required type of transfer, which could be target receive 
or target send etc. dma() checks the success of the trans- 
fer when the transfer is complete. 


i, 
aA 


4.0 Run-Time Software (Continue) 


in MODE E the interrupt mask can be set to only allow pari- 
ty, EOP and DMA phase mismatch interrupts. The interrupt 
jump table is loaded with the starting address of a service 
routine, which sets a flag to show an interrupt has occurred. 
The program can then sit in a loop waiting for this flag to go 
active. 


After the interrupt the cause has to be checked to ensure 
the transfer was successful, but this checking depends on 
the device installed. For a DP8490 the user can read the 
EASIISR and if any flag other than end of DMA is active an 
error has occurred. On such an error, status is set to 
CHECK CONDITION with a sense of ABORTED COM- 
MAND. The interrupt mask can be reset, masking off end of 
DMA and DMA phase mismatch, and the DMA mode in the 
EASIMR2 disabled. The interrupt service routine is set to 
jump to the general interrupt handler gen__int(). The inter- 
rupt must then be reset and the processor’s interrupts en- 
abled. 


In MODE E true end of DMA is detected, but in MODE N the 
end of DMA interrupt is generated when EOP, DACK and 
IOR or IOW are active concurrently. True end of DMA, after 
the transfer is complete, must be detected by software. 
REQ and ACK must both be inactive on three successive 
samples for true end of DMA. This additional code makes 
the MODE N DMA routine slower. After detecting this the 
user can check the end of DMA flag is active in the EA- 
SIBSR, giving status CHECK CONDITION and setting sense 
ABORTED COMMAND if it is not. The DMA bit is then reset 
and gen_int() called to ensure there was no parity or 
phase errors, and to reset the interrupt service routine. 


On return to the function single_dma_in() it will deassert 
the SCSI bus and return to the calling routine. 


4.4.2 Block Mode DMA 


blk_.dma__in() is the equivalent routine to single_dma_. 
in() initiating a block mode transfer to the initiator. send__ 
sense() could call this routine, after setting the DMA for 
block mode, and transfer the data using block mode, with 
no difference to the other software. The only difference be- 
tween these two routines is the setting of the EASIMR2 BLK 
mode bit. 


print_.cmd() is used to transfer the data to be printed from 
the initiator. This function checks that the transfer will not 
exceed the constraints of the queue and calls dma__data() 
to initiate a block mode transfer. dma__data() sets the EASI 
and DMA registers for a block mode target receive, with the 
data size set by print_cmd() and the destination starting 
address equal to rear. dma() is again used to handle the 
interrupts. 


4.4.3 Determination of Data Block Length 


The block of data to be transferred for a print has been 
specified as a maximum length of BUFFLIM, but the value 
of this constant has to be evaluated. The two main consid- 
erations in this are the latencies of the bus and the SPC. 


Since this board is a printer controller it will be of a very low 
priority. Thus the device should not hold the bus for too 
great a time per transfer, as this would slow down initiator’s 
accesses of a high priority peripheral. The second consider- 
ation is the time that the target takes from selection to en- 
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tering a data phase, the data block must take longer than 
this to transfer, or the command is inefficient. Measure- 
ments taken on various models of personal computers 
showed that, with an Advanced Storage Concepts 
ASC-88T SCSI Host Adaptor, the time taken from the ini- 
tiator asserting SEL to the target commencing the data 
transfer is approximately 3 ms. 


The block mode DMA rate was measured as between 
200 kB/s and 500 kB/s limited by the DMA in the PC. A 
block length of 2 kB was selected, since this would take 
between 4 ms and 10 ms to transfer. Thus the data transfer 
time is greater than the selection to data phase time, but the 
overall time on the bus in not too long. 


4.5 PRINTING DATA 


Due to the inherent slowness of printers data can not be 
printed while the controller is in command of the SCSI bus. 
To prevent tying up the bus data is stored in a buffer and 
printed after BSY has been released. The function printit() 
handles the transfer of data to the printer. 


printit() checks the printer is not in an error condition, and 
transfers the byte of data at address front to the printer. The 
data is transferred through Port A of the PIO with BUSY and 
STROBE used to handshake the data. BUSY must be high 
and STROBE pulsed low a minimum of 0.5 ys for the printer 
to accept data. front is incremented, to point to the next 
byte to be transferred. To print out the queue printit() is 
called until front equals rear. 


If the function does detect an error it sets sense to the 
appropriate value, and implements any outstanding recon- 
nection. The printer is continually polled to determine when 
it comes back on-line, at which time the print continues. 


While the board is printing it must still be available for selec- 
tion. An initiator can reset every device on the SCSI bus if a 
target does not respond to a selection within a Selection 
Timeout, normally 250 ms. The interrupt service routine has 
been set to jump to main(), but the program is currently in 
main(), so this function must be re-entrant. 


main() is written in such a way that it will only process com- 
mands if it is unreserved and not printing, or reserved by the 
current initiator but not printing. If the board is reserved, but 
not by the current initiator, a status of RESERVATION CON- 
FLICT is returned. If the board is printing, and the reserving 
initiator attempts to send it another command a status of 
BUSY can be returned. 


However, the controller has a 30 kB print buffer, of which 
only 2 kB would be used at a time. It would be much more 
efficient to continue executing commands until the buffer is 
full. One method of achieving this can be seen in outbuf(). 
In this function a flag, called next, is set if the free space in 
the queue is greater than BUFFLIM. If a selection occurs 
while a print is on, this flag is checked and the command 
processed if it is active. If it is inactive a status of BUSY is 
returned. This method has the disadvantage that the initia- 
tor must continually poll the SPC to determine when it is 
ready to accept data. This ‘loads’ the SCSI bus and slows 
down the print, since the SPC will be responding to selec- 
tion. It also restricts other device’s use of the bus. The alter- 
native method of utilizing the buffer space is to use discon- 
nection and reconnection. 
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4.0 Run-Time Software (Continued) 
4.6 DISCONNECTION AND RECONNECTION 


4.6.1 Disconnection 


If an initiator sends the IDENTIFY message to the target, it 
can indicate that it supports disconnection by setting bit 6 of 
this message. If this bit is not set, or the message not sent, 
the initiator is assumed not to support disconnection, and 
no disconnection is attempted. This software uses discon- 
nection in two places; 1) the board is reserved, currently 
printing and selected by the reserving initiator; 2) the board 
has been released, but not finished printing. 


If the board is busy printing it can be advantageous to dis- 
connect from the reserved initiator after reading in the com- 
mand block, and then reconnect having ensured that the 
command can be implemented i.e., there is enough free 
space in the queue. For any other initiator the response is 
the same as before, the status of RESERVATION CON- 
FLICT is returned until the unit is released. After this the 
controller will disconnect from any initiator attempting to se- 
lect it, until it has enough free space in its buffer. 


disconnect() is the routine which carries out the disconnec- 
tion procedure. This can only take place after the command 
phase and before the data phase, with an initiator that sent 
the IDENTIFY message with the disconnection bit set. The 
target follows the Command Out phase with a Message In 
phase and sends the DISCONNECT message, after which it 
can drop BSY, to release the bus. If the DISCONNECT mes- 
sage is not sent the initiator will treat the deasserting of BSY 
as an illegal termination of command. Before releasing BSY 
exchange() is called to store the ID of the initiator and the 
command it wants to execute. resef() is again used to ini- 
tialize the interrupts and release BSY. 


disconnect() stores in a variable, recon__data, the amount 
of print buffer which will be required to execute the com- 
mand. For a print, this depends on the length of data to be 
transferred, for any other command the amount is zero. re- 
con__data is used to determine when the target can recon- 
nect to the initiator i.e., once there is enough space free in 
the buffer. 


After disconnection the program will return to printing, at 
which point it may be selected by another initiator. As it can 
only disconnect from one initiator at a time it must return a 
status of BUSY. 


In outbuf() it can be seen that reconnection takes place 
when the free space in the print buffer is greater than the 
number of bytes to be transferred. reconnect() calls the 
functions which action the correct reconnection procedure, 
beginning with arbitration. 


4.6.2 Arbitration 


Arbitration requires two functions, one for MODE E another 
for MODE N, due to the fundamental difference in their 
methods of arbitration i.e, MODE E is interrupt driven, 
MODE N is polled. These two functions, Narbitrate() and 
Earbitrate(), carry out the same basic operation, arbitrate 
for the bus until successful, but do so in distinctly different 
ways. 

To arbitrate for the bus a device must wait for a Bus Free 
Phase, when BSY is continuously inactive for 400 ns with 
SEL inactive. After a Bus Free Delay of 800 ns the SCSI 
device should assert BSY, and assert its SCSIID bit on the 
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bus. After a further 2.2 ws Arbitration Delay the data bus 
should be examined, and the device with the highest priority 
SCSI ID bit asserted wins arbitration. 


In MODE N the EASIODR should be written with the SCSIID 
and the arbitration bit in the EASIMR2 set. The interrupts 
must be initialized to cause a jump to routine servn(). The 
EASI will wait for a Bus Free Phase then, after a Bus Free 
Delay, it will assert BSY, and put the contents of the 
EASIODR onto the bus. The user must poll the AIP bit of the 
EASIICR to determine when arbitration has begun and 
check the LA bit to ensure that arbitration has not been lost. 
The LA bit is set if another initiator asserts SEL during arbi- 
tration. If AIP is active and LA inactive the user must exam- 
ine the EASICSD to determine whether it is the highest pri- 
ority device arbitrating. If arbitration is lost the arbitration bit 
in the EASIMR2 must be reset and the whole procedure 
begun again. The device shows it has won arbitration by 
asserting SEL. An interrupt during MODE N arbitration is 
treated as a selection, so servn() enables parity, since there 
is no parity checking during arbitration, and calls main(). 


In MODE E arbitration is interrupt driven, allowing the 
board to continue printing while waiting to arbitrate. 
For a busy SCSI bus typically many milliseconds,. and 
potentially many seconds, can be taken up arbitrating. 
In MODE E this time can be utilized, thus increasing the 
system throughput. For this application the time gained 
is used to continue printing, in other applications, such 
as a disk controller, it could be used in data cacheing, 
overlapped seeks, etc. 


In MODE E arbitration the EASIODR must be written with 
the SCSIID and parity checking cancelled in the EASIMR2. 
The interrupts are set to allow selection and arbitration inter- 
rupts, with the jump table loaded with serva(). This sets a 
flag to show an interrupt has occurred. The enhanced arbi- 
tration is initiated, with a write to the arbitration bit of the 
EASIEMR. This causes the EASI to wait for a Bus Free 
Phase; delay a Bus Free Delay; assert BSY and the EA- 
SIODR; delay an Arbitration Delay then interrupt the proces- 
sor. The interrupt causes the flag to be set that shows the 
state of arbitration should be examined. While waiting for 
this interrupt the printer carries on printing out data, until 
front equals rear. 


After the interrupt is detected the EASIISR can be read to 
determine the cause. If it is not an arbitration interrupt parity 
checking is enabled and the interrupt treated as a selection, 
by calling main(). \f the interrupt is signalling the com- 
mencement of arbitration, the procedure :is the same as in 
MODE N, with the LA bit of the EASIICR being examined, 
and priority determined by reading the EASICSD. If arbitra- 
tion is lost, interrupts must be reset, the arbitration bit in the 
EASIEMR reset, and the whole procedure begun again. If 
arbitration is successful the user asserts SEL. 


Function printarb() is used to print data during arbitration in 
the same way as printit() does normally. The difference 
here is that the arbitration interrupt should be serviced as 
quickly as possible. 


This routine must be left if an interrupt occurs. Instead, of 
waiting for the printer to come on-line if an error occurs this 
routine simply does not send the character. 


4.0 Run-Time Software (Continued) 


4.6.3 Reselection 


When arbitration has been won the disconnected initiators 
ID and command block must be restored, and the initiator 
reselected. This reselection is carried out by function rese- 
lect(). 


The EASISER is cleared to stop it responding to the rese- 
lection and the initiator ID bit written into the EASIODR 
along with the SCSIID. 1/O must be asserted to show this is 
a reselection. The EASIODR is asserted onto the bus and 
the relevant arbitration bit, depending on MODE reset. This 
deasserts BSY. Parity checking is enabled, and the board 
waits a selection timeout delay of 250 ms for the initiator to 
respond, by asserting BSY. If it does not, RST is asserted, 
resetting the whole SCSI bus. 


lf the initiator does respond, the target must assert BSY, 
then deassert SEL and take the EASIODR off the bus. For 
MODE E the interrupt mask can be set, and the arbitration 
interrupt reset. Reselection is now complete. 


4.6.4 Reconnection 


After reselect() the IDENTIFY message is sent by the target 
with the disconnect bit set. The command that was previ- 
ously sent is processed, if this message is received suc- 
cessfully. After processing the command status and the 
COMMAND COMPLETE message are returned. reset() is 
again used to set the interrupts and release BSY. 


If a print was not current at the time of reconnection, and 
the reconnected command was PRINT, this is handled with- 
in reconnect(). As long as the status is GOOD the print is 
carried out. However, reconnect() will be mostly called from 
outbuf(), when the queue has enough free space to pro- 
cess the outstanding command. Any reconnection missed 
by outbuf() is captured in main(). 


4.7 ERROR HANDLING 


Throughout this document the handling of errors has been 
discussed as the errors arose, but there are some remaining 
to be discussed. These are phase or parity errors during 
command transfers and message errors. 


4.7.1 General Error Handling 


While this board is connected to the SCSI bus, with BSY 
active, gen_Jnt() is generally used to handle interrupts. 
This routine responds to an unexpected interrupt by check- 
ing the parity and phase flags, in the EASIBSR for MODE N, 
the EASIISR for MODE E. It then resets the interrupts, be- 
fore setting appropriate flags. Sense is set to ABORTED 


COMMAND with a status of CHECK CONDITION if an error ° 


has occurred. , 


After calling se/ect(), to respond to selection, main() then 
Calls function set_up(), which sets the mask and jump ta- 
ble to respond to an interrupt. This is also the routine which 
checks to see if ATN is asserted. If it is getmes() is called to 
enter the Message Out phase and fetch the IDENTIFY mes- 
sage. messout() processes the message. This is where the 
target determines if the initiator supports disconnection. 


If an error occurs during se/ect() or set-up(), detected by 
gen_int(), the board sends relevant status and a message 
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of COMMAND COMPLETE, before releasing the bus. No 
attempt is made to recover from the error. Similarly, if a 
phase error occurs during the command phase, status and 
sense are returned. However, if a parity error occurs during 
a command phase, the target can attempt a recovery by 
sending the RESTORE POINTERS message. This message 
instructs the initiator to reset the command pointer to the 
beginning of the command block, allowing the target to re- 
enter the Command Out phase and re-transfer the com- 
mand block. If there is a parity error again, status is re- 
turned, along with the COMMAND COMPLETE message. If 
the second transfer is successful, the command execution 
continues as normal. 


4.7.2 Message Errors 


If an initiator wishes to respond to a message sent by the 
target it indicates this by asserting ATN, before releasing 
ACK to finish the transfer. The target should then enter the 
Message In phase, and transfer message bytes until ATN 
goes inactive, up to 256 bytes. If the initiator attempts to 
send more than this the target will send the MESSAGE RE- 
JECT message and terminate the command with status of 
CHECK CONDITION and sense set to ABORTED COM- 
MAND. If a parity error occurs during the message transfer, 
the target must wait until the transfer is complete, then in- 
struct the initiator to resend all previous message bytes, by 
asserting REQ before changing phase. If the parity error 
occurs again the command will be terminated with status of 
CHECK CONDITION and sense ABORTED COMMAND. 


The relevant functions for message phases are messin(), 
getmes() and messout(). messin() is used to send a mes- 
sage to the initiator, while getmes() fetches a message 
from the initiator. messout() processes the message sent 
by the initiator. The supported messages are now explained. 


IDENTIFY: establishes the use of a greater message set, 
indicates the ability to support, or not support, disconnection 
and gives a LUN number, if necessary. 


ABORT: if the reserving initiator sends this message to the 
target it causes the board to be reset. 


BUS DEVICE RESET: This is similar to ABORT, except any 
initiator can implement it, resetting the board. 


MESSAGE PARITY ERROR: On receiving this message the 
target attempts to resend the last message sent, and if this 
fails, terminates the command with status of CHECK CON- 
DITION and sense set to HARDWARE ERROR. 


MESSAGE REJECT: the targets response to this message 
is determined by the message being rejected. If the last 
message sent was COMMAND COMPLETE, the MESSAGE 
REJECT is ignored, since the initiator must support the 
mandatory message. A MESSAGE REJECT in reply to a 
DISCONNECT causes the disconnection to be cancelled. If 
it was in reply to a MESSAGE REJECT sent, the command 
is terminated with a status of CHECK CONDITION and 
sense set to HARDWARE ERROR. If the message sent was 
IDENTIFY (during reconnection) the target immediately 
goes to the Bus Free Phase and aborts the command. No 
Status or Message In phases are attempted, though sense 
is set to HARDWARE ERROR. 
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4.0 Run-Time Software (continued) 


It should be noted that messin() has been written to only 
allow getmes() to be called, from inside messin(), once. 
Alternatively on parity error the target and initiator could 
eternally cycle, sending each other the MESSAGE PARITY 
ERROR message. 


4.7.3 Non-Recoverable Errors 


The following are errors which occur during selection, so 
severe that system operation is terminated, with an error 
code displayed on the LED. 


The first two concern a DP5380. 


Error 4 
Wrong interrupt flags active. 


Error 5 
SEL inactive. 
These errors concern either a DP5380 or a DP8490. 


Error 6 
SCSIID bit not active on bus. 


Error 7 
More than two bits active on bus. 


The final errors are for a DP8490 only. 


Error 8 
SCSI parity error. 


Error 9 
Select flag inactive. 


5.0 User Guide 


The SCSI Printer Controller (SPC) is a Small Computer Sys- 
tem Interface target board, which can use either the 
DP5380 Asynchronous SCSI interface (ASI) or DP8490 En- 
hanced Asynchronous SCSI Interface (EASI). It can be se- 
lected and used by an initiator as described in the 
ANSX3.131- 1986 SCSI standard as defined by the ANSI 
X3T9.2 committee. This document will explain the installa- 
tion of SPC, and show how it can be used in a system. By 
way of example a description is given of how the SPC can 
be used with an Advanced Storage Concepts ASC-88 IBM 
PC-SCSI Manager IIT host adaptor. 


5.1 INSTALLATION 


This section explains how the board must be set up before 
use, and the type of connectors required to interface to it. 
Any reference made to an EASI also applies for an ASI. 


scsi 
connector 


terminators 


5.1.1 POWER 


The SPC can be installed in a Personal Computer (PC) 
where it takes power from the backplane. There are two 
connections to + 5V and two to ground. These are the only 
connections made to the backplane. Alternatively power 
can be taken from the available connector block (Figure 
§. 1). 

When the board receives power the LED will come on, and 
stay on if the board passes its self diagnostics. If it fails an 
error message will be displayed by the LED, indicating the 
source of error. This will be further explained in section 
5.1.5. If the LED does not come on some fatal error has 
occurred. 


5.1.2 SCSI CONNECTOR 


The SCSI bus should consist of a 50: way flat ribbon cable a 
maximum of 6.0 meters long. Both ends of this cable should 
have all SCSI lines terminated, with a 3309 resistor to 
ground and a 2200 resistor to power. SCSI devices are 
daisy chained along this cable, with SCSI signals common 
to all devices. 


The SPC contains sockets for two DP8490 or DP5380 de- 
vices, one a PLCC socket the other DIL. Only one of these 
sockets should contain a device. 


To comply with the regulations on terminating resistors six 
SIL resistor packs are available between the SCSI connec- 
tor and the EASI DIL package (Figure 5.17). \f this board is 
not to be used at the end of the SCSI cable all of these six 
packs must be removed. The resistors have been socketed 
for this purpose. 


An option available in the SCSI standard is to supply termi- 
nator power on the cable, so terminators at either end of the 
bus can use the same power. If the device at one end of the 
bus is unpowered its terminators can receive power from 
the cable, and the bus will operate correctly. It should be 
noted that other manufacturer’s CMOS devices will not work 
in this configuration since if not powered they pull the SCSI 
lines low. National Semiconductor’s DP5380 and DP8490 
have special input protection to prevent this. 


Pin 26 on the SCSI connector is the terminator power pin, 
which can be left floating by leaving the jumper in position 2, 
see Figure 5.2. By moving the jumper to position 1 the termi- 
nator power is supplied to this pin. Figure 5.3 shows the two 


possible configurations. Terminator power is fed through a ~ — 


Schottky barrier diode to prevent a backflow of power into 
the board. 


4321 LED 


switches 


printer 
connector 


TL/F/10082-6 


FIGURE 5.1 
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LINK 
jumper 
jumper 
Position 1 Position 2 
FIGURE 5.2 
position 2 
Pin 26 of SCSi 
connector 
floating 


3300 


All SCSI lines 


TL/F/10082-7 


FIGURE 5.3 


5.1.3 SWITCH BLOCK SETTINGS 


The switch block is included to allow the user to select the 
SCSI ID of the SPC. This is used to identify the board during 
selection phases and determine its priority in arbitration. 
The SCSI ID is read in as a three bit binary number and 
converted in software to an eight bit pattern, with one bit 
active. For an ID of 0 the least significant bit is active, for an 
ID of 7 the most significant bit is active. 


The three bit number is taken from the switch block (see 
Figure 5.7), using switches 1, 2 and 3. 1 is the most signifi- 
cant bit, 4 is unused. These switches should be set to give a 
unique ID for this bus. An ID of 0 is suggested, making the 
printer the lowest priority device on the bus. These switches 
must be set up before power is applied, as they are only 
checked during the board diagnostics. 


5.1.4 PRINTER CONTROLLER 


The printer connector is a standard IBM 25 way ‘D’ type 
connector. The SPC software controls data transfers to the 
printer using the BUSY and STROBE signals. 


5.1.5 ERROR MESSAGES 


Non-recoverable errors cause a four bit binary number to be 
displayed by the LED. This indicates the source of error. 


The LED displays the number by occulting for 1 second to 
show a 1, 14 second to show a 0. The code is displayed 
most significant bit first, with the LED on for 1 second be- 
tween bits. The error number is repeatedly displayed, be- 
tween breaks of 2 seconds when the LED is on. 


The error numbers, and their cause, are shown below. The 
first four errors are generated during the board diagnostics, 
the others occur when a selection fails. The SCSI controller 
will be referred to as an EASI, unless the error is specific to 
either a DP5380 or DP8490. These possible differences are 
due to the DP8490’s more extensive testing, and because it 
handles a selection differently. 


Error 0 
The DMA could not be accessed. This is possibly a dam- 
aged device. 
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Error 1 
EASI can not be accessed. Device could be damaged, or 
not properly terminated. 


Error 2 
DP8490 has failed loopback test. Device could be dam- 
aged. 


Error 3 


DP8490 has failed the loopback DMA test. In this test a 
DMA transfer to memory from the DP8490 is attempted. 
Failure here could indicate an error in memory, processor, 
DMA, DP8490 or PALs. 


\ 
These first four errors concern problems internal to the 
board. The following errors indicate a bus problem that oc- 
curred while the board was waiting for selection. 


Error 4 
DP5380 error flag active. 


Error 5 
DP5380 found select line inactive. Possible selection 
timeout or bus error. 


Error 6 
EASI ID bit not active on bus. Possible selection timeout 
or bus error. 


Error 7 

EASI detected more than two bits active on bus. During a 
selection phase the initiator can only assert its own ID and 
the targets ID on the bus. This indicates a bus error. 


Error 8 
DP8490 SCSI parity error. Error on bus. 


Error 9 
DP8490 select flag inactive. This is board hardware error, 
possibly in DP8490 or PAL, possibly interrupt line. 


For any of these problems the user should try switching the 
device on and off again. For bus errors the cable and termi- 
nators should be checked along with any other devices on 
the bus. 
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5.0 User’s Guide (continueg) 


5.2 DRIVER SOFTWARE 


By way of example it will be shown how software can be 
written to drive the SPC from an ASC-88 host adaptor, in- 
stalled in a PC. The ASC-88, like many commercially avail- 
able host adaptors, handles all low level SCSI signal con- 
trols. The user controls the command to be implemented by 
means of a Job Control Block, JCB, which is passed to it. 


The software required to use an ASC-88 is on the supplied 
floppy disk. This disk contains both the source code, ex- 
plained later, and the executable code. This is called 
printout.exe and can be implemented in the form: 


printout filename 


The filename supports the MS-DOS use of directories and 
paths: 


e.g., printout a: /ASC /ASC.C 


The second executable command, called stoprint.exe, can 
be used to terminate a print. When this command is execut- 
ed the SPC flushes the print queue and initializes the printer. 


5.2..1 SEQUENCE OF COMMANDS 


Although the SPC requires no prescribed sequence of SCSI 
commands an initiator must reserve the unit before a 
print can take place. Otherwise the sequence of com- 
mands specified here indicate how the SPC could be used. 


Any print should begin with a TEST UNIT READY com- 
mand. On receiving this command the SPC tests the printer 
to ensure it has paper and is not in an error condition. If the 
status of GOOD is returned the user should then attempt 
RESERVE UNIT. If the command is successful the SPC will 
only execute commands from this initiator. This prevents 
print data from two or more sources being mixed. 


The user then sends PRINT commands with a maximum 
length of data per transfer of 2 kB. If the file to be printed is 
larger than 2 kB the data must be sent in several blocks. 
This limit, set to minimize bus latency, is more fully ex- 
plained in Section 4.4.3. 


These PRINT commands transfer the data to the SPC print 
buffer. To check if an error occurred when the SPC attempt- 
ed to transfer the data to the printer the user can send a 
REQUEST SENSE command. If the returned data is NO 
SENSE the printer is still operational. Any other sense indi- 
cates an error. 


The final command sent is RELEASE UNIT. This allows the 
SPC to be used by other initiators. 
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5.2.2 ASC-88 SOFTWARE 


All ASC-88 software is written for a Microsoft® C compiler. 
File ASC.C contains the main run-time software. ASC 
STRUC.LIB sets up the structure which is used as a Job 
Control Block, while ASCCOM.LIB defines the JCBs for par- 
ticular SCSI commands. The routines used in ASC.C, other 
than SCSI command calls, are in ASCROT.LIB and 
UTIL.LIB. CONSTANT.H contains the constants used 
throughout these files. If the user wishes the SCSI ID of the 
target board to be anything other than zero they should 
change the value of TARGET__JD in this file, and recompile 
the code for both commands. 


STDIO.H is a Microsoft library containing constants, macro 
definitions and function declarations for |/O stream opera- 
tions. This controls opening files, reading files, detecting file 
ends and closing files. DOS.H, also a Microsoft library, han- 
dles the interface to MS-DOS®. This allows the user to set 
up registers and execute interrupts. The final Microsoft li- 
brary CONIO.H allows the user to fetch information from the 
keyboard. : 


The SCSI-BIOSTM EPROM in the ASC-88 is accessed by 
generating interrupt number forty. The value in the ‘AH’ reg- 
ister determines what SCSI-BIOS software is used. SCSI- 
PROT implements the SCSI command specified in the JCB 
whose starting address is passed in the ‘BX’ and ‘ES’ regis- 
ters. 


ASC.C must be compiled and loaded to produce a file print- 
out.exe. When executed this code opens the file specified in 
the command line and instigates the sequence of com- 
mands, outlined in the previous section, to print it out. After 
these commands the file is closed. 


If the printer enters an error state while communicating with 
the initiator a message will be displayed on screen and the 
user is given the option of terminating the print. If the print is 
to be continued the user must correct the printer error and 
press a key to restart the print. If an error occurs when the 
SPC has already received all the data from the PC the board 
will wait until the print error is corrected and continue print- 
ing. 

STOPRINT.C contains the run-time software required to ter- 
minate a print. This uses the library CHECK.LIB, which 
checks the success of a FLUSH BUFFER command. To 
terminate an unwanted long print the user can: take the 
printer off-line; press escape to leave printout; send the 
stoprint command. 
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